首页前端开发JavaScript一文带你搞懂JavaScript中的原型和原型链

一文带你搞懂JavaScript中的原型和原型链

时间2024-01-31 03:56:03发布访客分类JavaScript浏览699
导读:收集整理的这篇文章主要介绍了一文带你搞懂JavaScript中的原型和原型链,觉得挺不错的,现在分享给大家,也给大家做个参考。原型和原型链是JavaScript中的难点也是重点,下面本篇文章就来带大家搞懂原型和原型链,希望对大家有所帮助!如...
收集整理的这篇文章主要介绍了一文带你搞懂JavaScript中的原型和原型链,觉得挺不错的,现在分享给大家,也给大家做个参考。原型和原型链是JavaScript中的难点也是重点,下面本篇文章就来带大家搞懂原型和原型链,希望对大家有所帮助!

如果你对原型和原型链的了解还停留在一个很浅的、模棱两可的阶段,不妨来看看我的这篇文章,它应该能对你能有所帮助,如果对你有那么一丢丢帮助的话,欢迎点赞评论加转发。有问题和疑惑的话也可以在评论区留言,我会第一时间回复大家,如果觉得我的文章哪里有知识点错误的话,也恳请能够告知,把错的东西理解成对的,对我们这个行业来说,是致命的。

之前虽然也经常刷原型方面的面试题,但是总是停留在一个很浅的、对知识点模棱两可的阶段,而且经常忘记(这点相信大伙也是这样,哈哈哈),趁着元旦假期的最后一天(终于摸起了键盘),跟着b站一个视频过了下相关方面的知识,对此终于有了一个整体的理解。这里对其进行了一个整理和归纳。

呜呜呜,本猿在这里立誓,未来一周,不管多忙,都需要回顾一遍本文,
否则
否则
掘金永远抽bug。

先知道对应关系

PRototyPE:原型
__proto__:原型链(链接点)

  • 从属关系

    • prototype : 函数的一个属性 -> 不要想的太复杂,其实就是一个普通对象{ }
    • __proto__ : 对象上的一个属性 -> 不要想的太复杂,其实就是一个普通对象{ }
  • 对象的__proto__保存着对象的构造函数的prototype

  • 函数是特殊对象 所以__proto__在函数上也是存在的,且是个function

大家经常忽略忘记的一点:Object是个方法(构造函数),new Object是个实例对象!!!

console.LOG(Object) //typeof Object ==='function'console.log(new Object) //typeof new Object ==='object'

constructor

constructor就是实例化对象的构造函数

//test.constructor ->
 实例化test对象的构造函数 Testconsole.log(test.constructor===Test) //true//这里个人理解为永无止境的自身调用自身,求解,没找到相关文章。console.log(test.constructor.prototype.constructor===Test) //trueconsole.log(test.constructor.prototype.constructor.prototype.constructor===Test) //true//constructor允许更改function test2() {
    this.a=123}
    test.constructor=Test2console.log(test)

原型

function Test(){
}
    let test=new Test() //new完之后 test是个实例对象了console.log(test.__proto__===Test.prototype) //根据上面的对应关系表 可以知道结果为true//Test.prototype也是一个对象,所以他必须也得有__proto__//Test.prototype.__proto__已经到达终点了,终点是什么,终点就是Object构造函数,所以下面结果为tureconsole.log(Test.prototype.__proto__.constructor===Object)//且 按照上面对应关系中的规则和上条的结果,下条结果也是tureconsole.log(Test.prototype.__proto__===Object.prototype) // //终点为nullconsole.log(Object.prototype.__proto__) //null

能不能描述一下原型链

对象的__proto__保存着对象的构造函数的prototypeprototype又是个对象,所以也有自己的__proto__,这样往复到终点Object.__proto__,这样就形成了一个以__proto__为链接点(为key)值为构造方法的prototype对象的一根链条, 即为原型链。

//__proto__test{
      b:333,      a:1,      __proto__:Test.prototype={
          c:222,          b:2,          __proto__:Object.prototype={
              c:3,              __proto__:null          }
      }
 }
    

特殊的函数对象

重点:JS中,函数是一种特殊的对象!!!

记住文章开头的对应关系表

//函数是特殊对象 所以__proto__是存在的,且是个functionconsole.log(Test.__proto__) //functionconsole.log(Test.prototype) //object

Test既然是个函数,那么底层必然也是new Function实现的,那么

//对象的__proto__保存着对象的构造函数的prototypeconsole.log(Test.__proto__===Function.prototype) //true 这里是不是和关系表对应上了,能正常理解const obj={
}
    const obj2=new Object()console.log(Object) //functionconsole.log(typeof Object) //'function'

Function既然是个构造函数,那么他是不是也应该有__proto__prototype,是的,但是这里有一个特殊的点需要记住。

底层规则规定 :Function.__proto__===Function.prototype是相等的,且两者返回的都是一个function,我的理解是Function自己构造了自己。

//正常来说函数的Test.prototype应该是个object,//Function.prototype是个function,这也是一个特殊的点typeof Test.prototype==='object' //trueconsole.log(Function.__proto__) // 一个functionconsole.log(Function.prototype) // 一个function//Function既然是函数对象_,那么他的_proto__就指向他的构造函数的prototype,也就是//Function.__proto__===Function.prototype,自己调自己,这样理解是不是也没毛病。console.log(Function.__proto__===Function.prototype) //true//Object既然是个构造方法,那么底层也是new Functionconsole.log(Object.__proto__===Function.prototype) //true// 因为Function.__proto__===Function.prototype 所以下面代码是成立的(Object.__proto__===Function.__proto__)===true

hasOwnProperty和in

hasOwnProperty

hasOwnProperty用来判断是否是对象自身的属性(非原型链继承过来的)

let test={
    a:1,    b:2}
    Object.prototype.c=3console.log(test.hasOwnProperty('a')) //trueconsole.log(test.hasOwnProperty('b')) //trueconsole.log(test.hasOwnProperty('c')) //false

in

in用来检查对象是是否包含某个属性(包含原型链上的属性)

console.log('a' in test) //trueconsole.log('b' in test) //trueconsole.log('c' in test) //trueconsole.log('toString' in test) //trueconsole.log('d' in test) //false

【相关推荐:javascript学习教程

以上就是一文带你搞懂JavaScript中的原型和原型链的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

原型

若转载请注明出处: 一文带你搞懂JavaScript中的原型和原型链
本文地址: https://pptw.com/jishu/593448.html
命令行如何查看nodejs目录 JS中如何防止内存泄漏?聊聊5个常见内存错误

游客 回复需填写必要信息