美文网首页
JS学习——js继承方式

JS学习——js继承方式

作者: 锤子爱砸房子 | 来源:发表于2017-10-27 21:26 被阅读0次

一.原型链继承

原型链继承主要是通过修改原型中的prototype的指向,从而继承上级构造函数的公有属性

function Fn1 (name, age) {
    this.name = name;
    this.age = age;
}

    // Fn1扩展原型
Fn1.prototype.say = function () {
    alert('hello');
}

var father = new Fn1('大李', 30);

function Fn2 (name, age) {
    this.name = name;
    this.age = age;
}

两构造函数的结构图如下图


现在需要Fn2创建的实例也能够使用say函数。但是,实例中的__proto__属性是不允许进行修改的,所以要想达到目的只有更改Fn2prototype的指向。目前有1,2两条可修改的线路,但是对于线路2,即Fn1.prototype = Fn2.prototype来说,存在缺陷:如果以后对Fn2prototype的任何修改都会同时修改Fn1的prototype,所以线路2不可行,选择线路1进行修改

通过将上级函数的实例赋值给下级函数的原型,用来代替下级函数的原型,从而构造出原型链
Fn2.prototype = new Fn1();
以上就完成了原型链的搭建,但是为了原始结构的完整性,在Fn1的原型中修复constructor指向Fn2,即Fn2.prototype.constructor = Fn2

function Fn1 (name, age) {
    this.name = name;
    this.age = age;
}
// Fn1扩展原型
Fn1.prototype.say = function () {
    alert('hello');
}
var father = new Fn1('大李', 30);
function Fn2 (name, age) {
    this.name = name;
    his.age = age;
}
// 原型链构建
Fn2.prototype = new Fn1();
// constructor修复
Fn2.prototype.constructor = Fn2;
// Fn2扩展原型
Fn2.prototype.eat = function () {
    alert('fish');
}
var son = new Fn2('小李', 18);
console.log(son);

二.组合方式继承

Fn1Fn2创建实例时都会创建相同的属性,如何让私有属性也能继承呢?改变Fn1this指针到Fn2就能解决问题
callapply改进原型链
callapply用法相似,相同点是第一个参数都是改变this指针到指定对象。不同点是call其余参数为对象的属性,如:Fn1.call(Fn2, name, age);apply只有两个参数,第二个参数为属性组成的数组,如:Fn1.call(Fn2, [name, age])

// 只需将原来的Fn2改为如下即可
function Fn2 (name, age) {
    Fn1.call(this, name, age);// this指的是Fn2
    // Fn1.apply(this, [name, age]);    
}

所有组合方式继承的本质就是结合callapply函数对原型链进行进一步完善
组合方式继承不仅仅只能继承上级,还能继承多个对象的私有属性

function Fn2 (name, age, height, weight) {
    Fn1.call(this, name, age);

    Fn3.call(this, height); 
    Fn4.call(this, weight); 
}

三.寄生方式继承

son的打印结果可以看出,虽然从上级全部继承,但是上级的原有私有属性也继承到了prototype里且为undefined,以寄生方式继承的目的就是为了出去上级继承的空属性
如何才能把从上级继承的为undefined的属性去掉了?如果我们从上级只继承公有属性该多好,如果能继承有公有属性但没有私有属性的对象呢?
寄生方式继承的主要思想就是用一个临时的空的过渡函数去获取上级函数的prototype,然后让下级函数继承这个空过渡函数

// 创建过渡函数
function Temp(){}
// 替换过渡函数原型
Temp.prototype = Fn1.prototype;
// 原型方式继承
Fn2.prototype = new Temp();

通过过渡替换的方法先让Temp的原型变为Fn1的原型,因为Temp没有私有属性,所有继承的Fn2不会携带多余属性

相关文章

  • JS学习——js继承方式

    一.原型链继承 原型链继承主要是通过修改原型中的prototype的指向,从而继承上级构造函数的公有属性 两构造函...

  • 继承

    研究学习了js内部的继承方式,以及多种方式的优点和缺点 目前项目中的 以前项目中的 js中继承有多种方式 原型继承...

  • JS继承

    JS中的继承 许多OO语言都支持两种继承方式:接口继承和实现继承; 因为JS中没有类和接口的概念 , 所以JS不支...

  • js 的继承的几种方式

    js 继承有6种方式的代码。 js继承的6种方式[https://www.cnblogs.com/Grace-zy...

  • JS继承的实现的几种方式

    前言 JS作为面向对象的弱类型语言,继承也是非常强大的特性之一,那么如何在JS实现继承呢? JS继承的实现方式 既...

  • JavaScript 继承

    继承是JS中非常内容,原因就是JS没有地道的继承方式,我们只能通过各种方式来模拟面向对象中的继承。下面介绍几种常见...

  • js继承遇到的小问题

    这两天在看js继承方面,它不像OC那种传统的类继承。js继承方式还是挺多的。比如:原型继承、原型冒充、复制继承 原...

  • js对象的三种继承方式

    js对象的三种继承方式转载 2017年06月23日 15:07:56 13300一,js中对象继承对象的js中有三...

  • #js继承

    js继承的概念 js里常用的如下两种继承方式: 原型链继承(对象间的继承)类式继承(构造函数间的继承) 类式继承是...

  • js继承方式

    类式继承 构造函数继承 组合继承 类式继承 + 构造函数继承 原型式继承 寄生式继承 寄生组合式继承 寄生式继承 ...

网友评论

      本文标题:JS学习——js继承方式

      本文链接:https://www.haomeiwen.com/subject/sqwdpxtx.html