在Chrome中隐藏__proto__属性's控制台

hiding the __proto__ property in Chrome's console

本文关键字:控制台 proto Chrome 隐藏 属性      更新时间:2023-09-26

每当我在对象上键入console.log/console.dir时,总是显示的属性之一是__proto__,它是构造函数。

有什么办法可以隐藏这件事吗?

重新定义console.log:

console.log = function (arg) {
    var tempObj;
    if (typeof arg === 'object' && !arg.length) {
        tempObj = JSON.parse(JSON.stringify(arg));
        tempObj.__proto__ = null;
        return tempObj;
    }
    return arg;
};

这不会修改肯定需要__proto__的原始对象。

console.debug = function() {
  function clear(o) {
    var obj = JSON.parse(JSON.stringify(o));
    // [!] clone
    if (obj && typeof obj === 'object') {
        obj.__proto__ = null;
        // clear
        for (var j in obj) {
          obj[j] = clear(obj[j]); // recursive
        }
    }
    return obj;
  }
  for (var i = 0, args = Array.prototype.slice.call(arguments, 0); i < args.length; i++) {
    args[i] = clear(args[i]);
  }
  console.log.apply(console, args);
};

var mixed = [1, [2, 3, 4], {'a': [5, {'b': 6, c: '7'}]}, [null], null, NaN, Infinity];
console.debug(mixed);

使用Opera和Dragonfly。在其设置(脚本选项卡)中,您可以取消选中"显示原型"选项。

使用Object.create(null)创建不带__proto__ 的对象

如果您只想隐藏控制台中具有.__proto__的对象上显示的proto,则不能。虽然我不明白你为什么要。

顺便说一句,.__proto__不是对象的构造函数,而是它的[[Prototype]]链接。

尽管.__proto__很重要,但显然有一种方法可以隐藏控制台中的内容。当你尝试这样做时,就会证明这一点:

 for (var i in function.prototype) {
    console.log(i+": "+function.prototype[i].toString())
    }

会有一些东西没有记录到控制台上,我认为这正是整个主题的内容(IMO的答案应该允许所有原型,这样任何访问该主题的人都可以使用它)。

另外:__proto__不是构造函数。它是对象的最高优先级原型对象。重要的是,不要删除proto并将其单独处理,因为如果存在JavaScript所依赖的方法,那么整个事情就会变得一团糟。对于obj.constructor的构造函数来说,它并没有破坏整个该死的东西,它可能只是它的名字,构造函数,想象一下。

隐藏__proto__不值得(请参阅以下原因)

var old_log = console.log;
console.log = function ()
{
    function clearProto(obj)
    {
        if (obj && typeof(obj) === "object")
        {
            var temp = JSON.parse(JSON.stringify(obj));
            temp.__proto__ = null;
            for (var prop in temp)
                temp[prop] = clearProto(temp[prop]);
            return temp;
        }
        return obj;
    }
    for (var i = 0; i < arguments.length; ++i)
        arguments[i] = clearProto(arguments[i]);
    old_log.apply(console, arguments);
}
var mixed = [1, [2, 3, 4], {'a': [5, {'b': 6, c: {'d': '7'}}]}, [null], null, NaN, Infinity];
console.log([1, 2, 3], mixed);
old_log([1, 2, 3], mixed); // 4 comparison (original mixed has __proto__)

NaNInfinity不能用JSON进行克隆。在Chrome中,您还可以在开发工具的右侧获得行号。通过覆盖console.log,您将失去它。不值得把__proto__藏在那上面!