JS继承方法
2018-09-18 06:37:40来源:博客园 阅读 ()
1、原型链:
每个构造函数都有一个原型对象,且有一个指针指向该原型对象(prototype),原型对象都包含一个指向构造函数的指针(constructor),而实例都包含一个指向原型对象的内部指针(proto)。若实例的原型是另一个构造函数的实例,该实例的原型有一个指向另一个原型的指针,层层递进,构成原型链。
原型上的属性和方法为所有实例所共有,当访问一个实例属性时,首先会在实例中搜索该属性,如果没有找到该属性,则会继续搜索该实例的原型,沿着原型链网上搜索,到原型链末端或找到为止。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
// 子类 function Sub(){ this .property = 'Sub Property' } Sub.prototype = new Super() // 注意这里new Super()生成的超类对象并没有constructor属性,故需添加上 Sub.prototype.constructor = Sub ```缺点: 1 . 包含引用类型的原型属性会被所有实例共享,一个实例对引用类型属性进行修改,就是直接修改原型上的该属性; 2 . 在创建子类型的实例时,没有办法给超类型的构造函数传递参数。 注意:原型上的引用值属性和方法使用时均为指针,但构造函数中的不同,不同实例中的同名属性和方法也不相同!!! |
2、借用构造函数:
1
2
3
4
5
|
在子类型构造函数中,使用call或apply方法在将来新建的对象上执行父类构造函数 function Sub(){ Super.call( this , '参数' ) //将Super的属性和方法都复制了一遍 this .property = 'Sub Property' } |
- 实例并不是父类的实例,只是子类的实例
- 只能继承父类的属性和方法,不能继承父类原型上的属性/方法
- 无法实现函数复用(父类上的方法也都复制到最后的实例中,方法不能复用),每个子类都有父类属性和方法的副本,影响性能
3、组合继承:
1
2
3
4
5
6
|
function Sub(){ Super.call( this ) //第二次调用Super() Super中的属性和方法复制进来 this.property = 'Sub Property' } Sub.prototype = new Super() //第一次调用Super() Super.prototype上的方法则可以共享 // 注意这里new Super()生成的超类对象并没有constructor属性,故需添加上 Sub.prototype.constructor = Sub |
4、原型式继承:
1
2
3
4
5
|
function objectCreate(obj){ function F(){} F.prototype = obj return new F() } |
5、寄生式继承:
1
2
3
4
5
6
7
8
9
10
|
function objectCreate(obj){ function F(){} F.prototype = obj return new F() } function createSubObj(superInstance){ var clone = objectCreate(superInstance) //任何能够返回新对象的函数都适用 clone.property = 'Sub Property' return clone } |
6、寄生组合式继承:
1
2
3
4
5
6
7
8
9
10
|
function inheritPrototype(Super,Sub){ var superProtoClone = Object.create(Super.prototype) superProtoClone.constructor = Sub Sub.prototype = Super } function Sub(){ Super.call() Sub.property = 'Sub Property' } inheritPrototype(Super,Sub) |
7、ES6 extends继承
类的实质是基于原型的和基于构造函数的语法糖
类声明:class 类名 {类体} ;//类声明不会提升
类表达式:let 类名 = class 类名 {类体}
extends 来创建子类,并继承父类 : class 子类名 extends 父类名 {类体}
1
|
class Point{ .... } typeof Point // "function" Point === Point.prototype.constructor // true |
类的数据类型就是函数,类本身就指向构造函数。
使用的时候,也是直接对类使用new命令,跟构造函数的用法完全一致。
1
2
3
4
|
class Bar{ doStuff(){console.log( 'stuff' );} } var b = new Bar(); b.doStuff(); // "stuff" |
构造函数的prototype属性,在 ES6 的“类”上面继续存在。事实上,类的所有方法都定义在类的prototype属性上面。
1
2
3
4
5
6
|
//定义类 class Point{ constructor((x, y){ this .x = x; this .y = y; } toString(){ return '(' + this .x + ', ' + this .y + ')' ; } } |
1
2
3
4
5
6
7
8
9
|
class ColorPoint extends Point { consturctor(x,y,color){ super (x,y); // 调用父类的constructor(x, y) this .color = color; } toString(){ return this .color + " " + super .toString(); //调用父类的toString()方法 } }
|
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- js实现翻页后保持checkbox选中状态的实现方法 2020-03-25
- NiftyCube实现圆角边框的方法 2020-03-20
- 根据分辨率调用css文件的方法 2020-03-19
- JS简单去除数组中重复项的方法 2020-03-16
- javascript 中关于array的常用方法详解 2020-03-16
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash