我尝试使用JSON.stringify(object),但它不会在整个结构和层次结构上下降。
另一方面,console.log(对象)这样做,但我不能保存它。
在console.log输出中,我可以逐个展开所有的孩子,选择并复制/粘贴,但结构太大了。
我尝试使用JSON.stringify(object),但它不会在整个结构和层次结构上下降。
另一方面,console.log(对象)这样做,但我不能保存它。
在console.log输出中,我可以逐个展开所有的孩子,选择并复制/粘贴,但结构太大了。
当前回答
更新(06/2021):
谷歌增加了一个复制对象的菜单动作。右键单击对象,然后单击复制对象
旧的回答:
如果你有一个对象日志:
在控制台中右键单击对象,然后单击“存储为全局变量” 输出将类似于temp1 输入控制台副本(temp1) 粘贴到您最喜欢的文本编辑器
其他回答
更新: 现在只需单击鼠标右键
右键单击控制台面板中的> Save as,将记录的消息保存到一个文件中。
最初的回答:
您可以使用下面所示的devtools代码片段创建一个控制台。保存方法。它根据输入创建一个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
现在说这个有点晚了,但也许能帮到别人。我的解决方案似乎类似于OP所描述的问题,但也许这是Chrome现在提供的功能,但不是那时。 我尝试在对象被写入控制台后右键单击并保存.log文件,但给我的只是一个文本文件:
console.js:230 Done: Array(50000)[0…9999][10000…19999][20000…] 29999][30000…39999][40000…49999]length: 50000__proto__:数组(0)
这对谁都没用。
我最终做的是在代码中找到console.log(数据),在上面删除一个断点,然后在控制台中键入JSON. stringify(数据),显示整个对象为JSON字符串,Chrome控制台实际上给了你一个按钮来复制它。然后粘贴到文本编辑器中,这就是JSON
还有另一个开源工具可以让你把所有console.log输出保存在服务器上的一个文件中——JS LogFlush(插件!)。
JS LogFlush是一个集成的JavaScript日志解决方案,包括: 跨浏览器无ui替换console.log客户端。 日志存储系统-服务器端。
Demo
右键点击控制台..单击另存为..就是这么简单。您将得到一个输出文本文件
更新(06/2021):
谷歌增加了一个复制对象的菜单动作。右键单击对象,然后单击复制对象
旧的回答:
如果你有一个对象日志:
在控制台中右键单击对象,然后单击“存储为全局变量” 输出将类似于temp1 输入控制台副本(temp1) 粘贴到您最喜欢的文本编辑器