javascript中in和hasOwnProperty区别

本文探讨了JavaScript中的原型链工作原理,包括如何使用in操作符和hasOwnProperty()方法来检查属性的存在,以及delete操作符的作用。并通过一个Person构造函数示例展示了这些概念的实际应用。

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

prototype
  1. 每个函数都有一个 prototype 的对象属性,对象内有一个 constructor 属性,默认指向函数本身
  2. 每个对象都有一个 __proto__ 的属性,属相指向其父类型的 prototype

构造函数和普通函数并没有区别,使用 new 关键字调用就是构造函数,使用构造函数可以 实例化 一个对象

函数的返回值有两种可能

  1. 显式调用 return 返回 return 后表达式的求值
  2. 没有调用 return 返回 undefined
function People(name, age) {
  this.name = name;
  this.age = age;
}

var people = new People('Byron', 26);

构造函数返回值

  1. 没有返回值
  2. 简单数据类型
  3. 对象类型

前两种情况构造函数返回构造对象的实例,实例化对象正是利用的这个特性

第三种构造函数和普通函数表现一致,返回 return 后表达式的结果


JavaScript 中,`key in Object` `hasOwnProperty` 都用于检查对象是否具有某个属性,但它们的行为存在明显差异。 `key in Object` 是一个操作符,用于检测指定对象(右边)原型链上是否有对应的属性值。这意味着它不仅会检查对象自身的属性,还会检查对象从原型链上继承的属性。例如: ```javascript // 定义一个原型对象 const prototypeObj = { inheritedProperty: 'inherited value' }; // 创建一个对象并继承自 prototypeObj const myObj = Object.create(prototypeObj); myObj.ownProperty = 'own value'; // 使用 in 操作符检查属性 console.log('ownProperty' in myObj); // 输出: true console.log('inheritedProperty' in myObj); // 输出: true ``` 在上述代码中,`'ownProperty' in myObj` 返回 `true`,因为 `ownProperty` 是 `myObj` 自身的属性;`'inheritedProperty' in myObj` 也返回 `true`,因为 `inheritedProperty` 是 `myObj` 从原型链上继承的属性。 而 `hasOwnProperty` 是 `Object.prototype` 上的一个方法,所有继承了 `Object` 的对象都会继承到该方法。这个方法用于检测一个对象是否含有特定的自身属性,会忽略掉那些从原型链上继承到的属性。其语法为 `obj.hasOwnProperty(prop)`,其中 `obj` 是要检查的对象,`prop` 是要检查的属性名。例如: ```javascript // 定义一个原型对象 const prototypeObj = { inheritedProperty: 'inherited value' }; // 创建一个对象并继承自 prototypeObj const myObj = Object.create(prototypeObj); myObj.ownProperty = 'own value'; // 使用 hasOwnProperty 方法检查属性 console.log(myObj.hasOwnProperty('ownProperty')); // 输出: true console.log(myObj.hasOwnProperty('inheritedProperty')); // 输出: false ``` 在上述代码中,`myObj.hasOwnProperty('ownProperty')` 返回 `true`,因为 `ownProperty` 是 `myObj` 自身的属性;`myObj.hasOwnProperty('inheritedProperty')` 返回 `false`,因为 `inheritedProperty` 是 `myObj` 从原型链上继承的属性,而不是自身的属性。 综上所述,两者的主要区别在于 `key in Object` 会查找原型链,而 `hasOwnProperty` 只检查对象自身的属性,不会考虑原型链上的属性[^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值