in操作符/Object.keys()/ Object.getOwnPropertyNames()
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了in操作符/Object.keys()/ Object.getOwnPropertyNames()相关的知识,希望对你有一定的参考价值。
in操作符
function Person(){
}
Person.prototype.name = "Nicholas";
Person.prototype.age = 29;
Person.prototype.job = "Software Engineer";
Person.prototype.sayName = function(){
alert(this.name);
};
var person1 = new Person();
alert(person1.hasOwnProperty("name")); //false
alert("name" in person1); //true name属性在实例的原型中
person1.name = "Greg";
alert(person1.name); //"Greg" alert(person1.hasOwnProperty("name")); //true
alert("name" in person1); //true name属性在实例中
判断通过person对象能否访问到”name”属性。不管这个“name”属性是在person中访问到的还是在person的原型中访问到的,都会返回true。
var o = {
toString : function(){
return "My Object";
}
};
for (var prop in o){
if (prop == "toString"){
alert("Found toString"); // 在IE中不会弹框
} }
1.返回所有能够通过对象访问的、可枚举的属性,即包括实例中存在的属性也包括实例的原型中存在的属性。
2.在IE中enumerable属性为false的属性在for-in中不会显示出来,但是在别的浏览器中可以显示出来。这是IE早期版本的一个bug。
Object.keys()方法
function Person(){
}
Person.prototype.name = "Nicholas";
Person.prototype.age = 29;
Person.prototype.job = "Software Engineer";
Person.prototype.sayName = function(){
alert(this.name);
};
var keys = Object.keys(Person.prototype);
alert(keys); //"name,age,job,sayName"
var p1 = new Person();
p1.name = "Rob";
p1.age = 31;
var p1keys = Object.keys(p1);
alert(p1keys); //"name,age"
1.Object.keys()
方法接受一个对象参数,返回一个传进来的对象中的自身、可枚举属性的字符串数组。
2.如果传入的是实例的原型,返回的就是原型中的属性。如果传入的是实例,返回的就是实例中的属性。
3.此方法返回的属性都是可枚举的。
Object.getOwnPropertyNames()
用来获取对象自身的全部属性名。
如果想得到所有的实例属性,使用Object.getOwnPropertyNames()
方法,可以返回实例中所有的属性,包括不可枚举的属性,这是传递的参数应该是实例的原型。因为实例中找不到属性的时候回去实例的原型中找。
以上是关于in操作符/Object.keys()/ Object.getOwnPropertyNames()的主要内容,如果未能解决你的问题,请参考以下文章
JavaScript中in操作符(for..in)Object.keys()和Object.getOwnPropertyNames()的区别
[转] JavaScript中in操作符(for..in)Object.keys()和Object.getOwnPropertyNames()的区别
for-in vs Object.keys forEach 没有继承属性
对象属性 Object.getOwnPropertyNames() Object.keys for...in
可枚举属性和不可枚举属性(for...in循环和Objec.keys()和Object.getOwnPropertyNames())