理解Javascript对象(属性探测,删除属性,属性枚举)


属性探测

在大多数情况下,in操作符是探测对象中属性是否存在的最好的途径。然而在某些情况下,可能希望仅当一个属性是自有属性时才检查其是否存在。in 操作符会检查自有属性和原型属性,所以不得选择另一条途径:所有的对象都拥有hasOwnProperty()方法。

var person1 = {
    name: 'Nicholas',
    sayName: function () {
        console.log(this.name);
    }
};

console.log('name' in person1); // true
console.log(person1.hasOwnProperty('name')); // true

console.log('toString' in person1); // true
console.log(person1.hasOwnProperty('toString')); // false

删除属性

使用delete操作符来彻底移除对象的一个属性。

var person1 = {
    name: 'Nicholas'
};

console.log('name' in person1);

delete person1.name; // true
console.log('name' in person1); // false
console.log(person1.name); // undefined

属性枚举

如果只需要获取一个对象的属性列表以备程序将来使用,ECMAScript 5 引入了Object.keys()方法,它可以获取可枚举属性的名字的数组。

for in 循环返回的和Object.keys()返回的可枚举属性有一个区别。for in循环同事也会遍历原型属性而Object.keys()只返回自有(实例)属性。


发表评论

电子邮件地址不会被公开。

您可以使用这些HTML标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>