我尝试使用JSON.stringify(object)
,但它并没有涉及整个结构和层次结构。
另一方面console.log(object)
这样做,但我无法保存。
在console.log
输出中,我可以将所有子项一一展开,然后选择并复制/粘贴,但是结构非常重要。
我尝试使用JSON.stringify(object)
,但它并没有涉及整个结构和层次结构。
另一方面console.log(object)
这样做,但我无法保存。
在console.log
输出中,我可以将所有子项一一展开,然后选择并复制/粘贴,但是结构非常重要。
Answers:
更新: 您现在可以右键单击
在“控制台”面板中右键单击>另存为,将记录的消息保存到文件中。
原始答案:
您可以使用下面显示的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
如果您记录了一个对象:
Store as a global variable
temp1
copy(temp1)
您可以使用Chrome DevTools实用程序API copy()
命令将指定对象的字符串表示形式复制到剪贴板。
如果您有很多对象,那么您实际上可以对所有对象进行JSON.stringify()并继续将它们附加到字符串中。现在使用copy()
方法将完整的字符串复制到剪贴板。
有一个开源的javascript插件可以做到这一点-debugout.js
Debugout.js记录并保存console.logs,以便您的应用程序可以访问它们。完全披露,是我写的。它可以适当地格式化不同的类型,可以处理嵌套的对象和数组,并且可以选择在每个日志旁边放置一个时间戳。它还在一个位置切换实时记录。
SyntaxError: export declarations may only appear at top level of a module --> debugout.js:9
您可以使用库l2i
(https://github.com/seriyvolk83/logs2indexeddb)保存所有内容console.log
,然后调用
l2i.download();
下载带有日志的文件。
还有另一个开源工具,它允许您将所有console.log
输出保存在服务器上的文件中-JS LogFlush(插件!)。
JS LogFlush是集成的JavaScript日志记录解决方案,其中包括:
- 跨浏览器的无UI替换console.log-在客户端。
- 日志存储系统-在服务器端。
晚会真的很晚,但也许会帮助某人。我的解决方案似乎与OP所描述的有问题的解决方案相似,但也许这是Chrome现在提供的功能,但不是那时提供的。在将对象写入控制台后,我尝试右键单击并保存.log文件,但是给我的只是一个带有以下内容的文本文件:
console.js:230完成:Array(50000)[0…9999] [10000…19999] [20000…29999] [30000…39999] [40000…49999]长度:50000__proto__:Array(0)
这对任何人都没有用。
我最终要做的是console.log(data)
在代码中找到,在其上放置一个断点,然后键入JSON.Stringify(data)
控制台,该控制台将整个对象显示为JSON字符串,而Chrome控制台实际上为您提供了一个复制按钮。然后粘贴到文本编辑器中,其中有您的JSON