美文网首页
继承的写法

继承的写法

作者: 独钓寒江月 | 来源:发表于2019-08-25 23:56 被阅读0次

继承是什么?

现实生活中,继承是什么,大家应该都懂,不用多说。

那在 JavaScript 中,简单来说,就是一个对象拥有另个对象的属性和方法

怎么实现继承?

1. ES5实现继承(基于原型链):

function Human(name) {    // 创建一个 Human 构造函数
  this.name = name
}
Human.prototype.run = function () {  
  console.log('I can run')
}

function Man(name) {    // 创建一个 Man 构造函数
  Human.call(this, name)
  this.gender = '男'
}
Man.prototype.fight = function () {
  console.log('I can fight')
}

Man.prototype.__proto__ = Human.prototype    // 让 Man 的原型对象的 proto 指向 Human 的原型对象

以上代码,就可以实现继承。可以new Man(name)来生成一个带继承的实例

但是 IE 不支持这样的写法,在 IE 中,你要把

Man.prototype.__proto__ = Human.prototype

换成

var f = function(){}
f.prototype = Human.prototype
Man.prototype = new f()

至此,就实现了继承,Man 有了 Human 的 属性和方法。

那么上面的 new 又做了什么

(1) 创建一个新对象;
(2) 将构造函数的作用域赋给新对象(因此 this 就指向了这个新对象;
(3) 将这个空对象的proto指向了构造函数对象的prototype;
(4) 执行构造函数中的代码(为这个新对象添加属性) ;
(5) 返回新对象。

2. ES6 实现继承(class 和 extends):

ES6 引入的「类」是一个特殊的函数,它可以帮助我们进一步简化继承的操作,但它依旧是「基于原型」的而不是引入新的面向对象继承模型,类语法只不过是一种语法糖。

class Human {
  constructor(name) {
    this.name = name
  }
  run() {
    console.log('I can run')
  }
}

class Man extends Human {
  constructor(name) {
    super(name)
    this.gender = '男'
  }
  fight(){
    console.log('I can fight')
  }
}

可以看到 ES6 的写法比 ES5 的写法简洁了很多。
但是有个问题就是,它明明是个函数,但却不能被调用。

typeof Man     // "function"
Man ()      // Uncaught TypeError: Class constructor Man cannot be invoked without 'new'

相关文章

  • javascript继承的等价模块化写法

    写法一: 写法二: 写法三: 继承: 调用方式:

  • 继承的写法

    new 之后 发生了3件事情!!! // // // ES6 的 class 写法,共有属性 只 支持函数 代码 ...

  • 继承的写法

    继承是什么? 现实生活中,继承是什么,大家应该都懂,不用多说。 那在 JavaScript 中,简单来说,就是一个...

  • JavaScript 面向对象编程

    写法 ES6面向对象的写法---类继承

  • JS中继承的写法

    继承的两种写法 i.Prototype 写法 ii.Class写法 iii.两种方法的区别 两种方法都能实现继承,...

  • class-继承(es6)

    继承-JS 继承-class class-总结 Class 在语法上更加贴合面向对象的写法Class 实现继承更加...

  • JS中继承的写法

    继承是类和类之间的关系,继承使得子类别具有父类别的属性和方法。 js里常用的如下两种继承方式: 原型链继承(对象间...

  • JS中继承的写法

    继承是面向对象编程很重要的一个方面,让子类继承父类的某些属性和方法,是非常常见的需求。 prototype写法 假...

  • JS 中继承的写法

    下面做一个测试题: 写出一个构造函数 Animal 输入为空 输出为一个新对象,该对象的共有属性为 {行动: fu...

  • JS 中继承的写法

    什么是继承 继承(英语:inheritance)是面向对象软件技术当中的一个概念。如果一个类别B“继承自”另一个类...

网友评论

      本文标题:继承的写法

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