为了账号安全,请及时绑定邮箱和手机立即绑定

Javascript。从数组输出对象的内置函数时输出奇怪

Javascript。从数组输出对象的内置函数时输出奇怪

繁花如伊 2022-11-11 16:55:32
此示例基于https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/create参考https://jsfiddle.net/bmswqgz7/1/let ocn = Object.create(null);Object.setPrototypeOf(ocn, Object.prototype);//ocn.valueOf(); // shows {}//ocn.hasOwnProperty("x"); // shows "false"//ocn.constructor; // shows "Object() { [native code] }"console.log([ocn.toString(), ocn.valueOf(), ocn.hasOwnProperty("x"), ocn.constructor].join(' : ')); // Aconsole.log([ocn.toString(), ocn.valueOf()].join(' : '));  // B这里,A 线输出": : false : function Object() { [native code] }",B 线输出": [object Object]"。这很奇怪,因为在 A 行中,ocn.toString()没有ocn.valueOf()输出,在 B 行中,它没有输出任何 forocn.toString()和[object Object]for ocn.valueOf(),而我们期望ocn.valueOf()成为{}和ocn.toString()成为[object Object]。所以它忽略了 A 行的输出,而 B 行的输出是无序的。有人可以解释一下吗?如果我逐行输出值,它可以正常工作:https ://jsfiddle.net/bmswqgz7/2/
查看完整描述

1 回答

?
肥皂起泡泡

TA贡献1829条经验 获得超6个赞

有人可以解释一下吗?

JsFiddle 的控制台坏了

console.log("[object Object] : [object Object] : false : function Object() { [native code] }");

将输出乱码,而不是预期的字符串。


查看完整回答
反对 回复 2022-11-11
  • 1 回答
  • 0 关注
  • 76 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信