我尝试使用JSON.stringify(object)
,但它不会影响整个结构和层次结构。
另一方面console.log(object)
,这样做但我无法保存它。
在console.log
输出中,我可以一一展开所有子项并选择和复制/粘贴,但结构太大了。
我尝试使用JSON.stringify(object)
,但它不会影响整个结构和层次结构。
另一方面console.log(object)
,这样做但我无法保存它。
在console.log
输出中,我可以一一展开所有子项并选择和复制/粘贴,但结构太大了。
更新: 您现在可以右键单击
在控制台面板中右键单击 > 另存为以将记录的消息保存到文件中。
原答案:
您可以使用下面显示的这个 devtools 片段来创建一个 console.save 方法。它从输入创建一个 FileBlob,然后自动下载它。
(function(console){
console.save = function(data, filename){
if(!data) {
console.error('Console.save: No data')
return;
}
if(!filename) filename = 'console.json'
if(typeof data === "object"){
data = JSON.stringify(data, undefined, 4)
}
var blob = new Blob([data], {type: 'text/json'}),
e = document.createEvent('MouseEvents'),
a = document.createElement('a')
a.download = filename
a.href = window.URL.createObjectURL(blob)
a.dataset.downloadurl = ['text/json', a.download, a.href].join(':')
e.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null)
a.dispatchEvent(e)
}
})(console)
来源:http : //bgrins.github.io/devtools-snippets/#console-save
您可以使用Chrome DevTools Utilities APIcopy()
命令将指定对象的字符串表示复制到剪贴板。
如果您有很多对象,那么您实际上可以将所有对象 JSON.stringify() 并继续将它们附加到字符串中。现在使用copy()
方法将完整的字符串复制到剪贴板。
有一个开源 javascript 插件可以做到这一点 - debugout.js
Debugout.js 记录并保存 console.logs,以便您的应用程序可以访问它们。完全公开,我写了。它适当地格式化不同的类型,可以处理嵌套的对象和数组,并且可以选择在每个日志旁边放置一个时间戳。它还可以在一处切换实时日志记录。
这对派对来说真的很晚,但也许它会帮助某人。我的解决方案似乎与 OP 描述的有问题的解决方案类似,但也许这是 Chrome 现在提供的功能,但不是那时。在将对象写入控制台后,我尝试右键单击并保存 .log 文件,但给我的只是一个包含以下内容的文本文件:
console.js:230 完成: Array(50000)[0 ... 9999][10000 ... 19999][20000 ... 29999][30000 ... 39999][40000 ... 49999]length: 50000(__0proto)__: Array
这对任何人都没有用。
我最终做的是console.log(data)
在代码中找到 ,在其上放置一个断点,然后JSON.Stringify(data)
在控制台中输入,该控制台将整个对象显示为 JSON 字符串,Chrome 控制台实际上为您提供了一个复制它的按钮。然后粘贴到文本编辑器中,这是您的 JSON