如何从chrome控制台窗口复制对象?

时间:2016-12-08 05:45:34

标签: javascript google-chrome google-chrome-console

我试图将对象复制为文本,但它只显示[对象对象]。在此之前,我尝试过复制表示它是成功但不是现在。那是铬问题吗?

我尝试了什么? 只需右键单击对象并从chrome控制台窗口存储为全局变量,然后接下来只使用copy(temp6)命令并尝试粘贴到notepad ++中。


enter image description here

5 个答案:

答案 0 :(得分:22)

理想情况下,应使用您编写的copy命令复制对象。 我只是尝试过并为我工作。
您可以尝试做的其他事情是对该对象进行字符串化然后复制它 例

copy(JSON.stringify(temp6))

答案 1 :(得分:19)

如果对象已记录

  • 右键单击控制台中的对象,然后单击“存储为全局
  • 变量输出将类似于temp1
  • 复制并粘贴Chrome控制台中的代码,然后按Enter键

    (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)
    
    • 然后您可以使用该功能进行下载,

console.save(temp1中);

- 如果显示未捕获的TypeError:将循环结构转换为JSON

然后你需要decycle JSON对象并在chrome浏览器控制台中粘贴下面的代码并点击

if (typeof JSON.decycle !== "function") {
    JSON.decycle = function decycle(object, replacer) {
        "use strict";

        var objects = new WeakMap();     // object to path mappings

        return (function derez(value, path) {


            var old_path;  
            var nu;  

            if (replacer !== undefined) {
                value = replacer(value);
            }

            if (
                typeof value === "object" && value !== null &&
                !(value instanceof Boolean) &&
                !(value instanceof Date) &&
                !(value instanceof Number) &&
                !(value instanceof RegExp) &&
                !(value instanceof String)
            ) {


                old_path = objects.get(value);
                if (old_path !== undefined) {
                    return {$ref: old_path};
                }

                objects.set(value, path);

                if (Array.isArray(value)) {
                    nu = [];
                    value.forEach(function (element, i) {
                        nu[i] = derez(element, path + "[" + i + "]");
                    });
                } else {

                    nu = {};
                    Object.keys(value).forEach(function (name) {
                        nu[name] = derez(
                            value[name],
                            path + "[" + JSON.stringify(name) + "]"
                        );
                    });
                }
                return nu;
            }
            return value;
        }(object, "$"));
    };
}


if (typeof JSON.retrocycle !== "function") {
    JSON.retrocycle = function retrocycle($) {
        "use strict";

        var px = /^\$(?:\[(?:\d+|"(?:[^\\"\u0000-\u001f]|\\([\\"\/bfnrt]|u[0-9a-zA-Z]{4}))*")\])*$/;

        (function rez(value) {



            if (value && typeof value === "object") {
                if (Array.isArray(value)) {
                    value.forEach(function (element, i) {
                        if (typeof element === "object" && element !== null) {
                            var path = element.$ref;
                            if (typeof path === "string" && px.test(path)) {
                                value[i] = eval(path);
                            } else {
                                rez(element);
                            }
                        }
                    });
                } else {
                    Object.keys(value).forEach(function (name) {
                        var item = value[name];
                        if (typeof item === "object" && item !== null) {
                            var path = item.$ref;
                            if (typeof path === "string" && px.test(path)) {
                                value[name] = eval(path);
                            } else {
                                rez(item);
                            }
                        }
                    });
                }
            }
        }($));
        return $;
    };
}
  • 然后最终执行下载代码。

console.save(JSON.decycle(temp1));

答案 2 :(得分:2)

在采用count之前,您需要检查copy(JSON.stringify(count))对象以避免循环引用,请参阅here

答案 3 :(得分:1)

可以有很多方法可以做到这一点。一种方法是JSON.stringify(yourObject)然后复制输出。

答案 4 :(得分:1)

您可以在控制台中使用命令,如下所示: 我们的目标是:

  var object = {x:"xyz"}

现在在控制台中使用以下命令 -

 copy(JSON.stringify(object))

对象现在可用于剪贴板。您现在可以使用Ctrl + v来使用此对象。