日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JS繼承實現方法及優缺點詳解

瀏覽:151日期:2024-04-22 13:27:47

前言

JS作為面向對象的弱類型語言,繼承也是其非常強大的特性之一。那么如何在JS中實現繼承呢?讓我們拭目以待。

JS繼承的實現方式

既然要實現繼承,那么首先我們得有一個父類,代碼如下:

// 定義一個動物類function Animal (name) { // 屬性 this.name = name || ’Animal’; // 實例方法 this.sleep = function(){ console.log(this.name + ’正在睡覺!’); }}// 原型方法Animal.prototype.eat = function(food) { console.log(this.name + ’正在吃:’ + food);};

1、原型鏈繼承

核心: 將父類的實例作為子類的原型

function Cat(){ }Cat.prototype = new Animal();Cat.prototype.name = ’cat’;// Test Codevar cat = new Cat();console.log(cat.name);console.log(cat.eat(’fish’));console.log(cat.sleep());console.log(cat instanceof Animal); //true console.log(cat instanceof Cat); //true

特點:

非常純粹的繼承關系,實例是子類的實例,也是父類的實例 父類新增原型方法/原型屬性,子類都能訪問到 簡單,易于實現

缺點:

要想為子類新增屬性和方法,必須要在new Animal()這樣的語句之后執行,不能放到構造器中

無法實現多繼承

來自原型對象的所有屬性被所有實例共享(來自原型對象的引用屬性是所有實例共享的)(詳細請看附錄代碼: 示例1)創建子類實例時,無法向父類構造函數傳參

推薦指數:★★(3、4兩大致命缺陷)

2017-8-17 10:21:43補充:感謝 MMHS 指出。缺點1中描述有誤:可以在Cat構造函數中,為Cat實例增加實例屬性。如果要新增原型屬性和方法,則必須放在new Animal()這樣的語句之后執行。

2018-9-10 00:03:45補充:感謝 IRVING_J 指出。缺點3中的描述不夠充分。更正為:來自原型對象的所有屬性被所有實例共享。

2、構造繼承

核心:使用父類的構造函數來增強子類實例,等于是復制父類的實例屬性給子類(沒用到原型)

function Cat(name){ Animal.call(this); this.name = name || ’Tom’;}// Test Codevar cat = new Cat();console.log(cat.name);console.log(cat.sleep());console.log(cat instanceof Animal); // falseconsole.log(cat instanceof Cat); // true

特點:

解決了1中,子類實例共享父類引用屬性的問題 創建子類實例時,可以向父類傳遞參數 可以實現多繼承(call多個父類對象)

缺點:

實例并不是父類的實例,只是子類的實例 只能繼承父類的實例屬性和方法,不能繼承原型屬性/方法 無法實現函數復用,每個子類都有父類實例函數的副本,影響性能

推薦指數:★★(缺點3)

3、實例繼承

核心:為父類實例添加新特性,作為子類實例返回

function Cat(name){ var instance = new Animal(); instance.name = name || ’Tom’; return instance;}// Test Codevar cat = new Cat();console.log(cat.name);console.log(cat.sleep());console.log(cat instanceof Animal); // trueconsole.log(cat instanceof Cat); // false

特點:

不限制調用方式,不管是new 子類()還是子類(),返回的對象具有相同的效果

缺點:

實例是父類的實例,不是子類的實例 不支持多繼承

推薦指數:★★

4、拷貝繼承

function Cat(name){ var animal = new Animal(); for(var p in animal){ Cat.prototype[p] = animal[p]; } Cat.prototype.name = name || ’Tom’;}// Test Codevar cat = new Cat();console.log(cat.name);console.log(cat.sleep());console.log(cat instanceof Animal); // falseconsole.log(cat instanceof Cat); // true

特點:

支持多繼承

缺點:

效率較低,內存占用高(因為要拷貝父類的屬性) 無法獲取父類不可枚舉的方法(不可枚舉方法,不能使用for in 訪問到)

推薦指數:★(缺點1)

5、組合繼承

核心:通過調用父類構造,繼承父類的屬性并保留傳參的優點,然后通過將父類實例作為子類原型,實現函數復用

function Cat(name){ Animal.call(this); this.name = name || ’Tom’;}Cat.prototype = new Animal();// 感謝 @學無止境c 的提醒,組合繼承也是需要修復構造函數指向的。Cat.prototype.constructor = Cat;// Test Codevar cat = new Cat();console.log(cat.name);console.log(cat.sleep());console.log(cat instanceof Animal); // trueconsole.log(cat instanceof Cat); // true

特點:

彌補了方式2的缺陷,可以繼承實例屬性/方法,也可以繼承原型屬性/方法 既是子類的實例,也是父類的實例 不存在引用屬性共享問題 可傳參 函數可復用

缺點:

調用了兩次父類構造函數,生成了兩份實例(子類實例將子類原型上的那份屏蔽了)推薦指數:★★★★(僅僅多消耗了一點內存)

6、寄生組合繼承

核心:通過寄生方式,砍掉父類的實例屬性,這樣,在調用兩次父類的構造的時候,就不會初始化兩次實例方法/屬性,避免的組合繼承的缺點

function Cat(name){ Animal.call(this); this.name = name || ’Tom’;}(function(){ // 創建一個沒有實例方法的類 var Super = function(){}; Super.prototype = Animal.prototype; //將實例作為子類的原型 Cat.prototype = new Super();})();// Test Codevar cat = new Cat();console.log(cat.name);console.log(cat.sleep());console.log(cat instanceof Animal); // trueconsole.log(cat instanceof Cat); //true感謝 @bluedrink 提醒,該實現沒有修復constructor。Cat.prototype.constructor = Cat; // 需要修復下構造函數

感謝 @bluedrink 提醒,該實現沒有修復constructor。

Cat.prototype.constructor = Cat; // 需要修復下構造函數

特點:

堪稱完美

缺點:

實現較為復雜

推薦指數:★★★★(實現復雜,扣掉一顆星)

附錄代碼:

示例一:

function Animal (name) { // 屬性 this.name = name || ’Animal’; // 實例方法 this.sleep = function(){ console.log(this.name + ’正在睡覺!’); } //實例引用屬性 this.features = [];}function Cat(name){}Cat.prototype = new Animal();var tom = new Cat(’Tom’);var kissy = new Cat(’Kissy’);console.log(tom.name); // 'Animal'console.log(kissy.name); // 'Animal'console.log(tom.features); // []console.log(kissy.features); // []tom.name = ’Tom-New Name’;tom.features.push(’eat’);//針對父類實例值類型成員的更改,不影響console.log(tom.name); // 'Tom-New Name'console.log(kissy.name); // 'Animal'//針對父類實例引用類型成員的更改,會通過影響其他子類實例console.log(tom.features); // [’eat’]console.log(kissy.features); // [’eat’]

原因分析:

關鍵點:屬性查找過程

執行tom.features.push,首先找tom對象的實例屬性(找不到),

那么去原型對象中找,也就是Animal的實例。發現有,那么就直接在這個對象的features屬性中插入值。

在console.log(kissy.features); 的時候。同上,kissy實例上沒有,那么去原型上找。

剛好原型上有,就直接返回,但是注意,這個原型對象中features屬性值已經變化了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩一区二区三区不卡视频 | 日韩高清不卡一区二区| 日韩一级欧洲| re久久精品视频| 亚洲成人一区| 1000部精品久久久久久久久| 91精品国产成人观看| 香蕉久久精品| 亚洲一区区二区| 亚洲精品欧洲| 国产日韩视频| 精品女同一区二区三区在线观看| 精品中文字幕一区二区三区 | 99精品视频在线| 香蕉精品久久| 9色精品在线| 在线观看视频免费一区二区三区| 亚洲日韩视频| 国产亚洲高清一区| 精品视频国内| 91精品啪在线观看国产18| 黄色免费成人| 日韩三级视频| 麻豆国产精品视频| 深夜视频一区二区| 欧美中文字幕| 国产区精品区| 天堂av在线| 久久影院一区| 蜜臀国产一区二区三区在线播放| 日韩**一区毛片| 老司机免费视频一区二区| 久久精品91| 综合在线一区| 精品日韩一区| 国产一区导航| 国产精品亚洲欧美日韩一区在线 | av亚洲免费| 日韩精品中文字幕一区二区| 国产劲爆久久| 久久久久久网| 国产精品7m凸凹视频分类| 蜜桃传媒麻豆第一区在线观看| 国产欧美自拍| 亚洲性色av| 亚洲区欧美区| 给我免费播放日韩视频| 激情综合网五月| 日本v片在线高清不卡在线观看| 国产精品福利在线观看播放| 免费日韩视频| 国产成人精品一区二区三区视频 | 亚洲精品日韩久久| 国产精品magnet| 国产字幕视频一区二区| 欧美一级一区| 久久天堂av| 日本国产欧美| 亚洲a一区二区三区| 视频一区日韩| 亚洲天堂资源| 天海翼亚洲一区二区三区| 国产一区二区三区不卡av| 国产精品视区| 丰满少妇一区| 蜜臀精品一区二区三区在线观看 | 中文字幕高清在线播放| 久久成人一区| 国产成人免费| 亚洲一级淫片| 一本大道色婷婷在线| 日韩精品一区二区三区中文在线| 日韩深夜视频| 国产欧美三级| 亚洲综合电影一区二区三区| 国产激情精品一区二区三区| 怡红院精品视频在线观看极品| 嫩呦国产一区二区三区av| 亚洲高清二区| 国产激情久久| 在线观看一区| 99久久99视频只有精品| 久久超碰99| 男女男精品视频网| av高清一区| 黄色欧美在线| 国产日韩一区| 中文字幕av一区二区三区人| 久久国产小视频| 精品国产乱码久久久久久樱花| 亚洲人成高清| 久久国产精品99国产| 日韩精品一区二区三区免费观看| 欧美亚洲tv| 亚洲一二三区视频| 黄色精品网站| 日韩欧美一区二区三区在线观看 | 国产精品久久久久毛片大屁完整版| 91久久久久| 电影天堂国产精品| 国产一区国产二区国产三区| 日韩精品一区二区三区中文在线 | 免费人成在线不卡| 亚洲国产综合在线看不卡| 福利视频一区| 久久精品av麻豆的观看方式| 在线精品亚洲| 丝瓜av网站精品一区二区| 91久久国产| 色网在线免费观看| 国产一区国产二区国产三区| 老司机免费视频一区二区| 国产精品久久久免费| 国产亚洲人成a在线v网站| 亚洲欧美在线综合| 亚洲一区二区三区中文字幕在线观看| 欧美va天堂在线| 欧美aa国产视频| 激情五月综合网| 9色国产精品| 男人天堂欧美日韩| 日韩精品一二三四| 日韩精品一级中文字幕精品视频免费观看 | 亚洲激情社区| 99在线精品免费视频九九视| 激情六月综合| 精品一区毛片| 国产91久久精品一区二区| 久久精品亚洲欧美日韩精品中文字幕| 日韩免费视频| 久久国产欧美| 国产精品91一区二区三区| 欧美在线网站| 亚洲欧美视频| 亚洲理论在线| 国产欧美日韩视频在线| 久久影院资源站| 精品一区91| 日韩大片在线| 久久久777| 欧美女激情福利| 中文亚洲免费| 日韩精品一区第一页| 日本精品久久| 美腿丝袜在线亚洲一区| 97精品国产福利一区二区三区| 91精品xxx在线观看| 午夜日本精品| 一本一道久久a久久| 欧美片网站免费| 高清精品久久| 女人av一区| 视频一区二区不卡| 欧美日韩xxxx| 91av亚洲| 日韩中文字幕麻豆| 久久精品99国产国产精| 美女视频黄 久久| 日韩欧美综合| 香蕉精品999视频一区二区| 日韩精品高清不卡| 国产一区二区三区四区二区| 国产99精品| 91久久精品无嫩草影院| 精品国产一区二区三区av片| 91tv亚洲精品香蕉国产一区| 免费精品视频| 国产精品一区二区精品视频观看| 国产在线一区不卡| 中文在线不卡| 免费在线亚洲欧美| jiujiure精品视频播放| 91精品一区| 色吊丝一区二区| 亚洲精品一二三**| 91亚洲成人| 日韩专区在线视频| 精品久久亚洲| 国产精品91一区二区三区| 欧美另类中文字幕| 日韩欧美一区二区三区免费观看| 男人的天堂久久精品| 国产精品videossex| 午夜久久免费观看| 国产探花在线精品| 欧美久久精品一级c片| 国产日韩三级| 成人av二区| 久久精品国产一区二区| 亚洲欧美日韩一区在线观看| 国际精品欧美精品| 免费成人在线视频观看| 手机在线电影一区| 亚洲精品九九| 久久香蕉国产| 国产欧美日韩一区二区三区四区| 999国产精品| 欧美日韩99| 欧美特黄一区| 欧美www视频在线观看|