javascript中in和hasOwnProperty区别
2017-06-09 09:58
561 查看
in操作符只要通过对象能访问到属性就返回true。hasOwnProperty()只在属性存在于实例中时才返回true。
使用delete操作符则可以完全删除实例属性,从而让我们能巩固重新访问原型中的属性。
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();
var person2 = new Person();
alert(person1.hasOwnProperty("name"));//false
alert("name" in person1);//true
person1.name = "Greg";
alert(person1.name);//"Greg"
alert(person1.hasOwnProperty("name"));//true
alert("name" in person1);//true
delete person1.name;
alert(person1.name);//"Nicholas"
alert(person1.hasOwnProperty("name"));//false
alert("name" in person1);//true
每个对象都有一个
构造函数和普通函数并没有区别,使用
函数的返回值有两种可能
显式调用
没有调用
构造函数返回值
没有返回值
简单数据类型
对象类型
前两种情况构造函数返回构造对象的实例,实例化对象正是利用的这个特性
第三种构造函数和普通函数表现一致,返回
使用delete操作符则可以完全删除实例属性,从而让我们能巩固重新访问原型中的属性。
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();
var person2 = new Person();
alert(person1.hasOwnProperty("name"));//false
alert("name" in person1);//true
person1.name = "Greg";
alert(person1.name);//"Greg"
alert(person1.hasOwnProperty("name"));//true
alert("name" in person1);//true
delete person1.name;
alert(person1.name);//"Nicholas"
alert(person1.hasOwnProperty("name"));//false
alert("name" in person1);//true
prototype
每个函数都有一个prototype的对象属性,对象内有一个
constructor属性,默认指向函数本身
每个对象都有一个
__proto__的属性,属相指向其父类型的
prototype
构造函数和普通函数并没有区别,使用
new关键字调用就是构造函数,使用构造函数可以 实例化 一个对象
函数的返回值有两种可能
显式调用
return返回
return后表达式的求值
没有调用
return返回
undefined
function People(name, age) { this.name = name; this.age = age; } var people = new People('Byron', 26);
构造函数返回值
没有返回值
简单数据类型
对象类型
前两种情况构造函数返回构造对象的实例,实例化对象正是利用的这个特性
第三种构造函数和普通函数表现一致,返回
return后表达式的结果
相关文章推荐
- JavaScript中in和hasOwnProperty区别详解
- JavaScript中typeof,instanceof,hasOwnProperty,in用法区别
- javascript中in和hasOwnProperty区别
- JavaScript中typeof,instanceof,hasOwnProperty,in的用法和区别
- Javascript hasOwnProperty 方法 & in 关键字
- JavaScript isPrototypeOf和hasOwnProperty使用区别
- javascript 对象及原型继承有关的属性:constructor、prototype、isPrototypeOf、instanceof、in 、hasOwnProperty 等等
- Javascript hasOwnProperty 方法 & in 关键字
- JavaScript中in操作符(for..in)、Object.keys()和Object.getOwnPropertyNames()的区别
- 详谈js使用in和hasOwnProperty获取对象属性的区别
- JavaScript: in, hasOwnProperty, delete, for/in
- (转)JavaScript: in, hasOwnProperty, delete, for/in
- JavaScript isPrototypeOf和hasOwnProperty使用区别
- JavaScript isPrototypeOf和hasOwnProperty使用区别
- Javascript 中的 in, hasOwnProperty, delete, for/in
- JavaScript中in操作符(for..in)、Object.keys()和Object.getOwnPropertyNames()的区别
- js使用in和hasOwnProperty获取对象属性的区别
- javascript--- hasOwnProperty、instanceof 、typeof的区别
- JS中isPrototypeOf 和hasOwnProperty 的区别 ------- js使用in和hasOwnProperty获取对象属性的区别
- (转)JavaScript: in, hasOwnProperty, delete, for/in