搞清javascript中Object与Function的关系

Function与Object到底是什么关系呢?我们先使用instanceof进行判断一下:

使用instanceof判断

???

What?是不是感觉心中一万头草泥马奔过呢?为什Function在Object的原型链上,而Object又在Function的原型链上?下面一张图帮你理清它们的关系:

每个对象都会有一个原型,就是[[prototype]],在ES规范里该属性是隐藏的,但在浏览器中则以__proto__的形式暴露出来。我们现在来解释一下上面的关系:

  1. 所有函数都是Function函数的实例,而Object是一个构造函数,所以Object的原型,也就是Object.__proto__指向Function.prototype
  2. 由于Function本身也是一个函数,所以Function.__proto__指向Function.prototype
  3. 由于Function.prototype是一个对象,所以Function.prototype.__proto__指向Object.prototype
  4. Object.prototype.__proto__永远指向null

下面我们来验证一下上述结论:

现在你明白为什么Function instanceof Object 及Object instanceof Function的返回值都为true了吗?尝试用上面的结论来解释下吧!另外,满意的话就随手点个赞吧,o(* ̄▽ ̄*)ブ!

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值