JavaScript寄生組合式繼承原理與用法分析
本文實(shí)例講述了JavaScript寄生組合式繼承。分享給大家供大家參考,具體如下:
寄生組合式繼承
寄生組合式繼承,就是通過偽造對象來繼承屬性,通過原型鏈的混成形式來繼承方法。
這種技術(shù)的基本思路是:不必為了指定子類型的原型而調(diào)用超類型的構(gòu)造函數(shù),因?yàn)槲覀兯枰闹皇浅愋驮偷囊粋€副本而已(這一點(diǎn)正是組合繼承的問題,并且正是JavaScript這種原型式語言的強(qiáng)大之處,直接copy對象-原型對象)。本質(zhì)上,就是使用寄生式繼承來繼承超類型的原型,然后再將結(jié)果指定給子類型的原型。
function inheritPrototype(subType, superType){ var prototype = Object.create(superType.prototype); //創(chuàng)建超類型原型副本 prototype.constructor = subType; //修改原型副本的不同屬性 subType.prototype = prototype; //指定原型 } function SuperType(name){ this.name = name; this.colors = ["red", "blue", "green"]; } SuperType.prototype.sayName = function(){ console.log(this.name); } function SubType(name, age){ //繼承屬性 SuperType.call(this, name); //實(shí)例屬性 this.age = age; } //繼承方法 inheritPrototype(SubType, SuperType); SubType.prototype.sayAge = function(){ console.log(this.age); }; var instance1 = new SubType("Nicholas", 29); instance1.colors.push("black"); console.log(instance1.colors); //"red, blue, green, black" instance1.sayName(); //"Nicholas" instance1.sayAge(); //29
這里使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼,可得如下運(yùn)行結(jié)果:
這個是寄生組合式繼承的最簡單形式。這個函數(shù)接收兩個參數(shù):
1. 子類型構(gòu)造函數(shù)
2. 超類型構(gòu)造函數(shù)
在函數(shù)內(nèi)部,寄生組合式繼承最簡形式分為3個步驟:
1. 創(chuàng)建超類型原型副本;
2. 為創(chuàng)建的副本指定constructor屬性,從而彌補(bǔ)因?yàn)橹貙慡ubType原型而失去的默認(rèn)的constructor屬性,這個原型副本的constructor屬性變化:SuperType –> SubType;
3. 將該完善好的副本賦值給子類型的原型。
寄生組合式繼承的圖解如下:
寄生組合式繼承的高效率體現(xiàn)在它只調(diào)用了一次SuperType構(gòu)造函數(shù),并且因此避免了在SubType.prototype
上面創(chuàng)建不必要的,多余的屬性。與此同時,原型鏈還能保持不變。
更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
js實(shí)現(xiàn)獲取焦點(diǎn)后光標(biāo)在字符串后
這篇文章主要介紹了js實(shí)現(xiàn)獲取焦點(diǎn)后光標(biāo)在字符串后,原理就是獲得焦點(diǎn)后重新把自己復(fù)制粘帖一下,喜歡的朋友可以看看2014-09-09javascript勻速運(yùn)動實(shí)現(xiàn)方法分析
這篇文章主要介紹了javascript勻速運(yùn)動實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了JavaScript勻速運(yùn)動的具體實(shí)現(xiàn)步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-01-01javascript實(shí)現(xiàn)限制上傳文件大小
這篇文章主要介紹了javascript實(shí)現(xiàn)限制上傳文件大小的方法和示例,需要的朋友可以參考下2015-02-02AlertBox 彈出層信息提示框效果實(shí)現(xiàn)步驟
彈出層就是相對文檔或窗口定位的一個層,一般用來顯示提示信息、廣告等內(nèi)容,還可以配合覆蓋層來鎖定頁面。2010-10-10各種常用瀏覽器getBoundingClientRect的解析
getBoundingClientRect2009-05-05JavaScript 用fetch 實(shí)現(xiàn)異步下載文件功能
本文通過實(shí)例代碼給大家介紹了JavaScript 用fetch 實(shí)現(xiàn)異步下載文件功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-07-07autojs 螞蟻森林能量自動拾取即給指定好友澆水的實(shí)現(xiàn)方法
這篇文章主要介紹了autojs 螞蟻森林能量自動拾取即給指定好友澆水的實(shí)現(xiàn)方法,本文通過圖文并茂實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05