美文网首页
js 面向对象编程(二):构造函数的继承

js 面向对象编程(二):构造函数的继承

作者: downhill6 | 来源:发表于2019-04-26 01:38 被阅读0次

组合继承

原理:使用原型链实现对原型属性和方法的继承,而通过借用构造函数来实现对实例属性的继承。举例:

// 父类
const Person = function(name, age) {
    this.name = name
    this.age = age
}
Person.prototype.sayName = function() {
    console.log(this.name)
}
// 子类
const Male = function(name, age) {
    // 继承属性
    Person.call(this, name, age)
    this.gender = 'male'
}
// 继承方法
Male.prototype = new Person()
// 把新的原型中的 constructor 指回自身
Male.prototype.constructor = Male

// test
const p1 = new Male('whh', 23)
console.log(p1)
// Male {name: "whh", age: 23, gender: "male"}

图解

弊端:调用了两次父类的构造函数,导致原型中产生了无效的属性。

寄生组合式继承

原理:通过借用构造函数来继承属性,通过原型链的混成形式来继承方法。主要就是用一个空的构造函数,来当做桥梁,并且把其原型对象指向父构造函数的原型对象,并且实例化一个temp,temp会沿着这个原型链,去找到父构造函数的原型对象。举例:

// 父类
const Person = function(name, age) {
    this.name = name
    this.age = age
}
Person.prototype.sayName = function() {
    console.log(this.name)
}
// 子类
const Male = function(name, age) {
    // 继承属性
    Person.call(this, name, age)
    this.gender = 'male'
}
// 寄生式组合继承
const extend = function(subType, superType) {
    const Temp = function() {}
    // 把Temp构造函数的原型对象指向superType的原型对象
    Temp.prototype = superType.prototype
    // 用构造函数Temp实例化一个实例temp
    let temp = new Temp()
    // 把子构造函数的原型对象指向temp
    subType.prototype = temp 
    // 把temp的constructor指向subType
    temp.constructor = subType
}
// 使用
extend(Male, Person)

// test
const p1 = new Male('whh', 23)
console.log(p1) 
// Male {name: "whh", age: 23, gender: "male"}

图解

这个例子的高效率体现在它只调用了一次 SuperType构造函数,并且因此避免了在 SubType.prototype上面创建不必要的、多余的属性。与此同时,原型链还能保持不变;因此,还能够正常使用instanceofisPrototypeOf()

目前程序猿认为解决继承问题最好的方案

其他继承方式(不完美的)

参考: 掘金地址

原型式继承

// 原型式继承
function createObjWithObj(obj){ // * 传入一个原型对象
    function Temp(){}
    Temp.prototype = obj
    let o = new Temp()
    return o
}

// * 把Person的原型对象当做temp的原型对象
let temp = createObjWithObj(Person.prototype)

// * 也可以使用Object.create实现
// * 把Person的原型对象当做temp2的原型对象
let temp2 = Object.create(Person.prototype)

寄生式继承

// 寄生式继承
// 我们在原型式的基础上,希望给这个对象新增一些属性方法
// 那么我们在原型式的基础上扩展
function createNewObjWithObj(obj) {
    let o = createObjWithObj(obj)
    o.name = "whh"
    o.age = 23
    return o
}

拷贝继承

const extend2(Child, Parent) {
    let p = Parent.prototype
    let c = Child.prototype
        for (var i in p) {
        c[i] = p[i]
        }
  }

这个函数的作用,就是将父对象的prototype对象中的属性,一一拷贝给Child对象的prototype对象。使用的时候,这样写:

extend2(Male, Person)
let p1 = new Male("whh", 23);
console.log(p1.age) // 23

相关文章

  • RYF javascript笔记3

    4. 面向对象编程 4.1面向对象编程概述 4.1.1简介 4.1.1.1构造函数 js没有“类”,而改用构造函数...

  • 面向对象五

    面向对象高级二 总结 PHP 里的面向对象、继承方式 JS 里的继承方式 call(构造函数伪装) 和 proto...

  • JS进阶 -- 面向对象(二)构造函数 + 继承

    概述 本篇主要讲述构造函数和继承 构造函数 编程 编程主要分为函数式编程和面向对象编程 函数式编程 ==> 推崇函...

  • 3-javascript 构造函数

    js中面向对象编程是基于构造函数(consstructor)和原型链(prototype)的。 构造函数作为对象的...

  • JavaScript 面向对象编程

    JavaScript 快速入门 面向对象编程创建对象构造函数忘记写new怎么办?原型继承class继承 面向对象编...

  • js面向对象:构造函数的继承

    参考文档++Javascript面向对象编程(二):构造函数的继承今天要介绍的是,对象之间的"继承"的五种方法,怎...

  • 面向对象继承复习

    js基础的面向对象的继承 构造函数继承 这种方法的缺陷是只会继承构造函数上的实例属性,并不会继承原型对象上的属性,...

  • js原型prototype原型链__proto__以及必会的ne

    什么是构造函数 构造函数是典型的面向对象编程语言,js的对象语言体系,是基于构造函数和原型链的构造函数是生成对象实...

  • js 面向对象编程(二):构造函数的继承

    组合继承 原理:使用原型链实现对原型属性和方法的继承,而通过借用构造函数来实现对实例属性的继承。举例: 图解 弊端...

  • 面向对象编程的模式

    本节介绍 JavaScript 语言实际编程中,涉及面向对象编程的一些模式。 构造函数的继承 让一个构造函数继承另...

网友评论

      本文标题:js 面向对象编程(二):构造函数的继承

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