激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - js中實(shí)現(xiàn)繼承的五種方法

js中實(shí)現(xiàn)繼承的五種方法

2022-01-07 16:24菜小牛 js教程

這篇文章主要介紹了js中實(shí)現(xiàn)繼承的五種方法,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下

借用構(gòu)造函數(shù)

這種技術(shù)的基本思想很簡(jiǎn)單,就是在子類型構(gòu)造函數(shù)的內(nèi)部調(diào)用超類型的構(gòu)造函數(shù)。另外,函數(shù)只不過是在特定環(huán)境中執(zhí)行代碼的對(duì)象,因此通過使用apply()和call()方法也可以在新創(chuàng)建的對(duì)象上執(zhí)行構(gòu)造函數(shù)。

?
1
2
3
4
5
6
7
8
9
10
11
12
function Box(name){
 this.name = name
}
Box.prototype.age = 18
 
function Desk(name){
 Box.call(this, name) // 對(duì)象冒充,對(duì)象冒充只能繼承構(gòu)造里的信息
}
 
var desk = new Desk('ccc')
console.log(desk.name)   // --> ccc
console.log(desk.age)    // --> undefined

從中可以看到,繼承來的只有實(shí)例屬性,而原型上的屬性是訪問不到的。這種模式解決了兩個(gè)問題,就是可以傳參,可以繼承,但是沒有原型,就沒有辦法復(fù)用。

組合繼承

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
function Box(name){
 this.name = name
}
Box.prototype.run = function (){
 console.log(this.name + '正在運(yùn)行...')
}
 
function Desk(name){
 Box.call(this, name) // 對(duì)象冒充
}
 
Desk.prototype = new Box() // 原型鏈
 
var desk = new Desk('ccc')
console.log(desk.name)   // --> ccc
desk.run()         // --> ccc正在運(yùn)行...

這種繼承方式的思路是:用使用原型鏈的方式來實(shí)現(xiàn)對(duì)原型屬性和方法的繼承,而通過借用構(gòu)造函數(shù)來實(shí)現(xiàn)對(duì)實(shí)例屬性的繼承。

原型式繼承

原型式繼承:是借助原型可以基于已有的對(duì)象創(chuàng)建新對(duì)象,同時(shí)還不必因此創(chuàng)建自定義類型。講到這里必須得提到一個(gè)人,道格拉斯·克羅克福德在2006年寫的一篇文章《Prototype inheritance in Javascript》(Javascript中的原型式繼承)中給出了一個(gè)方法:

?
1
2
3
4
5
function object(o) {   //傳遞一個(gè)字面量函數(shù)
 function F(){}     //創(chuàng)建一個(gè)構(gòu)造函數(shù)
 F.prototype = o;    //把字面量函數(shù)賦值給構(gòu)造函數(shù)的原型
 return new F()     //最終返回出實(shí)例化的構(gòu)造函數(shù)
}

看如下的例子:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
function obj(o) {
 function F (){}
 F.prototype = o;
 return new F()
}
 
var box = {
 name: 'ccc',
 age: 18,
 family: ['哥哥','姐姐']
}
 
var box1 = obj(box)
console.log(box1.name)   // --> ccc
box1.family.push('妹妹')
console.log(box1.family)  // --> ["哥哥", "姐姐", "妹妹"]
 
var box2 = obj(box)
console.log(box2.family)  // --> ["哥哥", "姐姐", "妹妹"]

因?yàn)樯鲜龅拇a的實(shí)現(xiàn)邏輯跟原型鏈繼承很類似,所以里面的引用數(shù)組,即family屬性被共享了。

寄生式繼承

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
function obj(o) {
 function F (){}
 F.prototype = o;
 return new F()
}
function create(o){
 var clone = obj(o)   // 通過調(diào)用函數(shù)創(chuàng)建一個(gè)新對(duì)象
 clone.sayName = function(){   // 以某種方式來增強(qiáng)這個(gè)對(duì)象
  console.log('hi')
 }
 return clone   // 返回這個(gè)對(duì)象
}
 
var person = {
 name: 'ccc',
 friends: ['aa','bb']
}
 
var anotherPerson = create(person)
anotherPerson.sayName()   // --> hi

這個(gè)例子中的代碼基于person返回一個(gè)新對(duì)象————anotherPerson。新對(duì)象不僅具有person的所有屬性和方法,而且還有自己的sayHi()方法。在主要考慮對(duì)象而不是自定義類型和構(gòu)造函數(shù)的情況下,寄生式繼承也是一種有用的模式。使用寄生式繼承來為對(duì)象添加函數(shù),會(huì)由于不能做到函數(shù)復(fù)用而降低效率,這一點(diǎn)與構(gòu)造函數(shù)模式類似。

寄生組合式繼承

前面說過,組合繼承是Javascript最常用的繼承模式,不過,它也有自己的不足。組合繼承最大的問題就是無論什么情況下,都會(huì)調(diào)用過兩次超類型構(gòu)造函數(shù):一次是在創(chuàng)建子類型原型的時(shí)候,另一次是在子類型構(gòu)造函數(shù)內(nèi)部。沒錯(cuò),子類型最終會(huì)包含超類型對(duì)象的全部實(shí)例屬性,但我們不得不在調(diào)用子類型構(gòu)造函數(shù)時(shí)重寫這些屬性,再來看一下下面的例子:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
function SuperType(name){
 this.name = name;
 this.colors = ['red','black']
}
SuperType.prototype.sayName = function (){
 console.log(this.name)
}
function SubType(name, age){
 SuperType.call(this, name) // 第二次調(diào)用SuperType
 this.age = age
}
 
SubType.prototype = new SuperType() // 第一次調(diào)用SuperType
SubType.prototype.constructor = SubType
SubType.prototype.sayAge = function (){
 console.log(this.age)
}

第一次調(diào)用SuperType構(gòu)造函數(shù)時(shí),SubType.prototype會(huì)得到兩個(gè)屬性:name和colors。他們都是SuperType的實(shí)例屬性,只不過現(xiàn)在位于SubType的原型中。當(dāng)調(diào)用SubType構(gòu)造函數(shù)時(shí),又會(huì)調(diào)用一次SuperType構(gòu)造函數(shù),這個(gè)一次又在新對(duì)象上創(chuàng)建了實(shí)例屬性name和colors。于是,這兩個(gè)屬性就屏蔽了原型中的兩個(gè)同名屬性。即有兩組name和colors屬性:一組在實(shí)例上,一組在原型上。這就是調(diào)用兩次SuperType構(gòu)造函數(shù)的結(jié)果。解決這個(gè)問題的方法就是————寄生組合式繼承。
所謂寄生組合式繼承,即通過借用構(gòu)造函數(shù)來繼承屬性,通過原型鏈的混成形式來繼承方法。其背后的基本思路是:不必為了制定子類型的原型而調(diào)用超類型的構(gòu)造函數(shù),我們所需要的無非就是超類型原型的一個(gè)副本而已。本質(zhì)上,就是使用寄生式繼承來繼承超類型的原型,然后再將結(jié)果指定給子類型的原型。寄生組合式繼承的基本模式如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
function object(o) {
 function F (){}
 F.prototype = o;
 return new F()
}
function inheritPtototype(subType, superType){
 var prototype = object(superType.prototype) // 創(chuàng)建對(duì)象
 prototype.constructor = subType       // 增強(qiáng)對(duì)象
 subType.prototype = prototype        // 指定對(duì)象
}
 
function SuperType(name){
 this.name = name
 this.colors = ['red', 'white']
}
 
SuperType.prototype.sayName = function(){
 console.log(this.name)
}
 
function SubType(name,age){
 SuperType.call(this,name)
 this.age = age
}
 
inheritPtototype(SubType, SuperType)
 
SubType.prototype.sayAge = function(){
 console.log(this.age)
}
 
var instance = new SubType('ccc', 18)
 
instance.sayName()   // --> ccc
instance.sayAge()    // --> 18
console.log(instance)

控制臺(tái)打印出的結(jié)構(gòu):

js中實(shí)現(xiàn)繼承的五種方法

詳細(xì)的圖解:

js中實(shí)現(xiàn)繼承的五種方法

這個(gè)例子的高效率提現(xiàn)在它值調(diào)用了一次SuperType構(gòu)造函數(shù),并且因此避免了在SubType.prototype上面創(chuàng)建不必要的、多余的屬性。與此同時(shí),原型鏈還能保持不變;因此,還能夠正常使用instanceof和isPrototypeOf()。這也是很多大廠用的繼承方式。

以上就是js中實(shí)現(xiàn)繼承的五種方法的詳細(xì)內(nèi)容,更多關(guān)于js 實(shí)現(xiàn)繼承的資料請(qǐng)關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://www.cnblogs.com/cirry/p/js-inherit.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久精品亚洲国产奇米99 | 欧美日韩亚洲另类 | 在线看免费的a | 欧美另类69xxxxx 视频 | 精品一区二区久久久久久按摩 | 国产欧美一区二区三区免费看 | 毛片毛片| 天天夜夜草 | 国产一区二区三区在线免费观看 | 久久欧美亚洲另类专区91大神 | 午夜色视频在线观看 | 制服丝袜成人动漫 | 嫩呦国产一区二区三区av | 久久一区二区三区av | 久久亚色 | 日日爱夜夜操 | 一级成人欧美一区在线观看 | 91九色视频在线播放 | 中文字幕视频在线播放 | 无遮挡一级毛片视频 | 99re久久最新地址获取 | 久久99久久99精品 | 欧美一区二区三区不卡免费观看 | 国产精品9191 | 久久网一区二区 | 欧美jizzhd极品欧美 | 性少妇videosexfreexxx片 | 国产精品久久久久久久久久妇女 | 欧美一级特黄aaaaaaa什 | 宅男噜噜噜66一区二区 | 精品一区二区三区欧美 | 国产亚洲精品成人a | 九九热在线视频观看 | 亚洲白嫩在线观看 | 欧美精品日日鲁夜夜添 | 综合图区亚洲 | 午夜精品影院 | 久草在线手机视频 | 国产大片全部免费看 | 精品国产一区二区三区蜜殿 | 久久精品国产久精国产 |