美文网首页
JS里的继承

JS里的继承

作者: 阿小经 | 来源:发表于2019-01-13 14:53 被阅读0次
  • 什么是继承
  • 继承的原理
  • 如何完成JS的继承?

什么是继承

继承就是子类拥有父类的各种属性和方法
那什么是类?这里的JS的类即是函数,能产生对象的东西就是类。
继承需要两个类:父类和子类,在JS中的继承需要有2次对原型的搜索。

继承的原理

//原理
子类('参数'){
    父类.call(this,'参数')
}
子类.prototype.__proto__=父类.prototyp

如何完成JS的继承?

一、ES5中如何完成JS的继承?

1、声明一个父类函数,父类函数有一个name的属性和run()的方法

function Human(name){
     this.name = name
 }
Human.prototype.run = function(){
     console.log("我叫"+this.name+",我在跑")
     return undefined
 }

2、声明一个子类函数,并从父类函数中继承属性

function Man(name){
     Human.call(this, name) //是Human的属性
     this.gender = '男' //是自己的属性
 }
Man.prototype.fight = function(){
     console.log('xxx')
}

注意,Human.call(this, name)就是从父类继承属性,这句代码很重要

3、从父类函数继承方法

//添加一句这样的代码就可以了
Man.prototype.__proto__=Human.prototype

然而IE不兼容这个代码所以要换另一种方式

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

原因是什么?因为当 var a =new f()的时候
会发生5个步骤:

  • 产生一个空对象
  • this=空对象
  • this.proto_=f.prototype
  • 执行f.call(this,其他参数)
  • return 上一行述结果

所以需要声明一个空的函数f。

二、ES6中如何完成JS的继承?
class Human{
     constructor(name){
         this.name = name
     }
     run(){
         console.log("我叫"+this.name+",我在跑")
         return undefined
     }
 }
 class Man extends Human{
     constructor(name){
         super(name)
         this.gender = '男'
     }
     fight(){
         console.log('xxx')
     }
 }

从ES5改成ES6逻辑其实是一样的,只是写法换了一下。其中用关键字extends来继承父类,用super来call一下父类获得父类的属性。

三、ES5与ES6写法的优劣?

ES5的写法可以更直观的看清楚内存的变化,同时可以在方法中增加属性。而ES6的写法不能在方法中增加属性,暂时不支持。

相关文章

  • JS里的继承

    1. 继承 简介一层原型链搜索不叫继承,两层原型链的搜索才叫继承let a = new Array();a.__p...

  • JS里的继承

    什么是继承继承的原理如何完成JS的继承? 什么是继承 继承就是子类拥有父类的各种属性和方法那什么是类?这里的JS的...

  • #js继承

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

  • Js的继承

    js的继承 @(js)[继承, js, 前端] 组合继承是原性链继承和构造函数继承的合体,它汲取了二者各自的有点,...

  • JS继承

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

  • 面向对象五

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

  • JS里的类和继承

  • js继承遇到的小问题

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

  • JS中继承的实现

    JS中继承的实现 #prototype (js原型(prototype)实现继承) 全局的Function对象没有...

  • JavaScript 10

    js继承的概念 1.通过原型链方式实现继承(对象间的继承) 2.类式继承(构造函数间的继承) 由于js不像Java...

网友评论

      本文标题:JS里的继承

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