Object.getOwnPropertyNames
和Object.keys
在 javascript 中有什么区别?还有一些例子将不胜感激。
Object.getOwnPropertyNames 与 Object.keys
IT技术
javascript
2021-01-18 05:38:34
5个回答
有一点不同。Object.getOwnPropertyNames(a)
返回对象的所有自己的属性a
。Object.keys(a)
返回所有可枚举的自己的属性。这意味着如果你定义你的对象属性而不创建它们中的一些,enumerable: false
这两种方法会给你相同的结果。
测试很容易:
var a = {};
Object.defineProperties(a, {
one: {enumerable: true, value: 1},
two: {enumerable: false, value: 2},
});
Object.keys(a); // ["one"]
Object.getOwnPropertyNames(a); // ["one", "two"]
如果您定义了一个属性而不提供属性属性描述符(意味着您不使用Object.defineProperties
),例如:
a.test = 21;
那么这样的属性会自动成为可枚举的,并且两种方法都会生成相同的数组。
另一个区别是在数组Object.getOwnPropertyNames
方法的情况下将返回一个额外的属性,即length
.
var x = ["a", "b", "c", "d"];
Object.keys(x); //[ '0', '1', '2', '3' ]
Object.getOwnPropertyNames(x); //[ '0', '1', '2', '3', 'length' ]
创建对象时的文字符号与构造函数。这是让我着迷的东西。
const cat1 = {
eat() {},
sleep() {},
talk() {}
};
// here the methods will be part of the Cat Prototype
class Cat {
eat() {}
sleep() {}
talk() {}
}
const cat2 = new Cat()
Object.keys(cat1) // ["eat", "sleep", "talk"]
Object.keys(Object.getPrototypeOf(cat2)) // []
Object.getOwnPropertyNames(cat1) // ["eat", "sleep", "talk"]
Object.getOwnPropertyNames(Object.getPrototypeOf(cat2)) // ["eat", "sleep", "talk"]
cat1 // {eat: function, sleep: function, talk: function}
cat2 // Cat {}
// a partial of a function that is used to do some magic redeclaration of props
function foo(Obj) {
var propNames = Object.keys(Obj);
// I was missing this if
// if (propNames.length === 0) {
// propNames = Object.getOwnPropertyNames(Obj);
// }
for (var prop in propNames) {
var propName = propNames[prop];
APIObject[propName] = "reasign/redefine or sth";
}
}
所以在我的例子中,foo
如果我给它 cat2 类型的对象,这个函数就不起作用。
还有其他方法可以创建对象,因此其中也可能存在其他问题。
正如已经解释过的,.keys
不返回不可枚举的属性。
关于示例,一个陷阱案例是Error
对象:它的一些属性是不可枚举的。
所以虽然console.log(Object.keys(new Error('some msg')))
产量[]
,
console.log(Object.getOwnPropertyNames(new Error('some msg')))
产量["stack", "message"]
console.log(Object.keys(new Error('some msg')));
console.log(Object.getOwnPropertyNames(new Error('some msg')));
另一个区别是(至少对于 nodejs)“getOwnPropertyNames”函数不保证键顺序,这就是我通常使用“键”函数的原因:
Object.keys(o).forEach(function(k) {
if (!o.propertyIsEnumerable(k)) return;
// do something...
});
其它你可能感兴趣的问题