标签:ES5 组合 继承 age Father Son uname 构造函数
ES6中类的继承使用extends关键字,那么ES5中是怎么实现的呢?
ES5中采用构造函数和原型对象的组合方式模拟继承,所以也称为组合继承;
核心原理:通过call()借用父构造函数,并把父类型的this指向子类型的this;
这种继承,实际上是在调用子构造函数创建实例对象时,在子构造函数内调用了父构造函数,那么就可以获得父构造函数中的成员,同时修改被调用的父构造函数的this的指向为子函数即可,成员就会被继承到子函数中;
用一句话说:使用call()在子构造函数调用父构造函数,实现继承;记得修改父构造函数中的this为子函数中的this
function Father(uname, age){ this.uname = uame; this.age = age; } function Son(uname, age){ Father.call(this); }
借用原型对象继承方法
Son.prototype = new father();//因为可以通过原型链访问到Father的原型对象中的方法 Son.prototype.constructor = Son;//上面的赋值操作,会使Son的constructor指向Father
标签:ES5,组合,继承,age,Father,Son,uname,构造函数 来源: https://www.cnblogs.com/joeynkay/p/12734884.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。