我们来看下面的代码:
var obj = {};
var x = Symbol();
Object.defineProperties(obj, {
[x]: {
value: true,
writable: true
},
"property2": {
value: "Hello",
writable: false
}
// etc. etc.
});
console.log(obj[x])
这是有效的吗?
使用本机 Object.defineproperties 代码,我们在 console.log 中得到 true。
使用 zone.js 的 polyfill
其形式为:
Object.defineProperties = function (obj, props) {
Object.keys(props).forEach(function (prop) {
Object.defineProperty(obj, prop, props[prop]);
});
return obj;
};
我们得到了 console.log 的相同代码未定义。
这是因为 Object.keys 函数。我用谷歌搜索了一下,没有找到任何地方是否应该允许这样做。
我用谷歌搜索了一下,没有找到任何地方是否应该允许这样做。
在这种情况下,您可以随时检查规格§ 19.1.2.3 Object.defineProperties(O, 属性) http://www.ecma-international.org/ecma-262/6.0/#sec-object.defineproperties.
它使用OwnPropertyKeys内部方法 http://www.ecma-international.org/ecma-262/6.0/#sec-ordinary-object-internal-methods-and-internal-slots-ownpropertykeys,它确实列出了对象的所有字符串和符号键。
这是因为Object.keys
功能
正确的。它应该是Object.getOwnPropertyNames(props).concat(Object.getOwnPropertySymbols(props))
反而。您可能想提交 zone.js 的错误。不过我确实想知道为什么 ES5 需要一个 polyfillObject.defineProperties
当你使用 ES6 符号时函数?
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)