JS检测属性位于对象本身还是来自于其原型链

学习原型链时有这个疑问,之前查过了但是老是忘记,现在记录一下,避免忘记。

参考:https://blog.csdn.net/weixin_40920953/article/details/88295651

1.in操作符

in 操作符会在通过对象能够访问给定属性时返回true,无论该属性存在于对象本身还是其原型链上。

    function Person(name) {
      this.name = name
    }
    let obj = new Person('Tom')
 
 
    Person.prototype.gender = 'male'
    Person.prototype.code = 23
    
    console.log("name" in obj) // true
    console.log('code' in obj) // true
    console.log('gender' in obj) // true

 2.obj.hasOwnProperty(prop)

hasOwnProperty() 方法会返回一个布尔值,指示对象自身属性中是否具有指定的属性。

    function Person(name) {
      this.name = name
    }
    let obj = new Person('Tom')
    
    Person.prototype.gender = 'male'
    Person.prototype.code = 23
 
    console.log(obj.hasOwnProperty('name')) // true
    console.log(obj.hasOwnProperty('code')) // false

 3.两者结合判断属性位于对象本身还是来自于其原型链

    function Person(name) {
      this.name = name
    }
    let obj = new Person('Tom')
 
    Person.prototype.gender = 'male'
    Person.prototype.code = 23
 
    function propertyFormPrototype(obj, prop) {
      return obj.hasOwnProperty(prop) && prop in obj
     //当return为true时表示属性位于对象本身
    }
    console.log(propertyFormPrototype(obj, 'name')) // true
    console.log(propertyFormPrototype(obj, 'code')) // false

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值