成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

瀏覽:123日期: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
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产精品一二三四区| 影音先锋久久精品| 精品动漫3d一区二区三区免费版| 日韩欧美第一区| 国产曰批免费观看久久久| 在线视频观看一区| 日韩精品视频网站| 亚洲欧美日韩精品综合在线观看| 日韩一区中文字幕| 在线日韩中文| 亚洲欧美另类综合偷拍| 国产一区再线| 国产精品国产自产拍高清av| 国产一区二区三区四区hd| 精品国产一区二区精华| 成人美女在线观看| 欧美精品一区视频| 欧美影院一区| 国产精品欧美一级免费| 韩日精品在线| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲午夜激情在线| 亚洲免费av网站| 中文高清一区| 亚洲一本大道在线| 久久久国产亚洲精品| 日韩中文字幕91| 在线观看中文字幕不卡| 韩国av一区二区三区在线观看| 欧美日本在线视频| 国产白丝精品91爽爽久久| 精品久久国产字幕高潮| 91亚洲精品久久久蜜桃网站| 国产亚洲精久久久久久| 欧美韩日精品| 中文字幕日本不卡| 一本久道久久久| 亚洲成人av资源| 在线视频综合导航| 国产成人综合网站| 久久精品网站免费观看| 亚洲第一网站| 亚洲小说欧美激情另类| 日本高清无吗v一区| 琪琪久久久久日韩精品| 在线观看免费亚洲| 国产精品性做久久久久久| 欧美一级二级三级蜜桃| 本田岬高潮一区二区三区| 久久精品亚洲麻豆av一区二区| 伊人久久婷婷色综合98网| 亚洲图片一区二区| 欧美日韩亚洲综合一区| 99精品视频在线免费观看| 亚洲日本va午夜在线电影| 美日韩免费视频| 久久精品国产精品青草| 欧美精品一区二区三区蜜桃 | 欧美一区二区福利在线| 亚洲欧美综合一区| 亚洲影视资源网| 欧美日韩久久久一区| 波多野结衣在线一区| 亚洲色图在线播放| 在线视频一区二区三| aa级大片欧美| 夜夜精品浪潮av一区二区三区| 欧美无砖专区一中文字| gogogo免费视频观看亚洲一| 亚洲欧美偷拍卡通变态| 欧美色爱综合网| 色综合视频在线观看| 亚洲一区二区在线观看视频| 555夜色666亚洲国产免| 欧美午夜不卡| 日韩电影在线免费看| 亚洲精品一区二区三区福利| 99精品热6080yy久久| 久久精品国产第一区二区三区| 26uuu欧美日本| 国产精品综合色区在线观看| 国产乱妇无码大片在线观看| 国产精品美女视频| 91久久精品国产91性色tv| 成人av免费在线观看| 亚洲一区二区三区中文字幕 | 欧美视频在线观看一区| 91丨九色丨蝌蚪丨老版| 亚洲一区二区三区中文字幕在线| 在线不卡免费欧美| 亚洲天堂男人| 国产一区二区三区免费播放| 中文字幕视频一区| 欧美精品v国产精品v日韩精品| 欧美午夜精品| 国内精品伊人久久久久av一坑| 国产亚洲精品久| 欧美三片在线视频观看| 亚洲精品极品| 成人综合在线观看| 午夜精彩视频在线观看不卡| 国产亚洲视频系列| 在线一区二区三区四区五区| 亚洲欧美综合| 激情欧美一区二区三区在线观看| 国产精品国产自产拍高清av王其| 欧美精品一级二级三级| 日韩视频在线观看国产| jiyouzz国产精品久久| 琪琪久久久久日韩精品| 综合久久给合久久狠狠狠97色| 欧美日韩国产一级| 99国产精品私拍| 成人av电影在线播放| 免费观看30秒视频久久| 国产精品国产三级国产aⅴ入口 | 99精品国产高清一区二区| 成人的网站免费观看| 喷水一区二区三区| 亚洲日韩欧美一区二区在线| 精品va天堂亚洲国产| 欧美三级电影网| 免费在线播放第一区高清av| 91麻豆swag| 国内精品视频666| 亚洲成人资源网| 日本一二三不卡| 91精品国产综合久久久蜜臀粉嫩| 国产精品美女诱惑| 欧美一区高清| 国产一区二区三区免费在线观看| 亚洲尤物在线视频观看| 国产日韩欧美在线一区| 在线成人午夜影院| 可以看av的网站久久看| 韩国在线一区| 欧美精品色网| 成人免费毛片app| 日本成人中文字幕| 亚洲欧洲制服丝袜| 国产女同性恋一区二区| 日韩欧美中文字幕精品| 欧美性大战久久| 久久亚洲精选| 一区二区三区视频在线播放| 欧美三级在线| 91首页免费视频| av成人老司机| 成人午夜激情片| 国产不卡视频在线观看| 韩国精品免费视频| 天天射综合影视| 亚洲国产综合人成综合网站| 亚洲国产岛国毛片在线| 精品国产1区2区3区| 日韩欧美不卡在线观看视频| 678五月天丁香亚洲综合网| 欧美日韩亚洲综合在线| 日本道色综合久久| 久久国产日韩| 美女日韩在线中文字幕| 99riav国产精品| 亚洲人人精品| aⅴ色国产欧美| 999在线观看精品免费不卡网站| 国内一区二区三区在线视频| 欧美成人综合| 亚洲欧美一区在线| 91在线小视频| 国产精品福利电影一区二区三区四区| 久久久99免费| 久久久久久电影| 国产午夜亚洲精品羞羞网站| 精品福利视频一区二区三区| 精品免费一区二区三区| 精品乱人伦小说| 精品福利一区二区三区免费视频| 日韩免费观看高清完整版| 日韩欧美一卡二卡| 欧美不卡一二三| 久久一区二区视频| 国产亚洲一本大道中文在线| 国产欧美日韩久久| 中文字幕一区二区三| 国产精品久久久久影院色老大 | 亚洲一区日本| 免费久久99精品国产自| 久久精品午夜| 欧美伊人久久久久久午夜久久久久| 欧美性大战久久久| 91麻豆精品国产91久久久久久久久 | a亚洲天堂av| 欧美黄免费看| 一本久道久久综合婷婷鲸鱼| 亚洲欧美不卡| 欧美这里有精品| 欧美一区二区三区四区高清 | 奇米777欧美一区二区| 美美哒免费高清在线观看视频一区二区 | 国产农村妇女精品一区二区|