Javascript程式設計中幾種繼承方式比較分析_javascript技巧
本文實例分析了Javascript程式設計中幾種繼承方式比較。分享給大家參考,具體如下:
開頭
從'嚴格'意義上說,javascript並不是一門真正的物件導向語言。這種說法原因一般都是覺得javascript作為一門弱類型語言與類似java或c#之類的強型語言的繼承方式有很大的區別,因而默認它就是非主流的面向對象方式,甚至竟有很多書將其描述為'非完全面向對象'語言。其實個人覺得,什麼方式並不重要,重要的是是否具有物件導向的思想,說javascript不是物件導向語言的,往往都可能沒有深入研究過javascript的繼承方式,故特撰此文以供交流。
為何需要利用javascript實作繼承
早期pc機器的效能確實不敢恭維,所有的壓力全在伺服器端,客戶端瀏覽器純屬擺設。再加上那時流行的table佈局以及電話線的上網方式導致瀏覽一個網頁十分的卡;而今互聯網時代飛速發展,個人電腦硬體得到了極大提升,客戶端瀏覽器的性能也十分的酸爽, web開發的模式也在悄悄改變:服務端不再像以前那樣“辛苦”,取而代之的是盡可能的讓瀏覽器承擔更多的任務,如此一來,壓力分攤到每個客戶端上,企業不但節省成本,隨之也讓web前端開發變的更加有趣──越來越多的前端框架層出不窮,甚至出現了許多前端的MVC框架。在這種背景下,javascript的角色已經絕對不是只做一些簡單的驗證,發送一些請求或操作一些DOM,更多的需要擔任類似前端路由和業務層的角色,並且javascript需要做大量的邏輯性任務,這裡面就包括前台資料的抽離(即model),而只有運用物件導向的思維才能很好的對抽離資料進行處理,因此繼承就在這裡顯得舉足輕重。
從一個簡單的需求開始
現在從前台抽離一個model名為Person,其有基本屬性name和age,默認每個人都會說話,因此將說話的功能say放在了原型對像上,以供每個實例享用。現在對Man來說,它需要繼承Person的基本屬性,並且在此基礎上加入自己特有的屬性。
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man() { //my own properties }
以下介紹幾種主流的繼承方式。
1.原型鏈繼承
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man() { } Man.prototype = new Person('pursue'); var man1 = new Man(); man1.say(); //hello, my name is pursue var man2 = new Man(); console.log(man1.say === man2.say);//true console.log(man1.name === man2.name);//true
這種繼承方式很直接,為了取得Person的所有屬性方法(實例上的和原型上的),直接將父類別的實例new Person('pursue')賦給了子類別的原型,其實子類別的實例man1,man2本身就是一個完全空的對象,所有的屬性和方法都得去原型鏈上去找,因而找到的屬性方法都是同一個。
所以直接利用原型鏈繼承是不切實際的。
2.利用建構子繼承
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man(name, age) { Person.apply(this, arguments); } //Man.prototype = new Person('pursue'); var man1 = new Man('joe'); var man2 = new Man('david'); console.log(man1.name === man2.name);//false man1.say(); //say is not a function
這裡子類別的在建構函數裡利用了apply去呼叫父類別的建構函數,從而達到繼承父類別屬性的效果,比直接利用原型鏈要好的多,至少每個實例都有自己那一份資源,但是這種辦法只能繼承父類別的實例屬性,因而找不到say方法,為了繼承父類別所有的屬性和方法,則就要修改原型鏈,從而引入了組合繼承方式。
3.組合繼承
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man(name, age) { Person.apply(this, arguments); } Man.prototype = new Person(); var man1 = new Man('joe'); var man2 = new Man('david'); console.log(man1.name === man2.name);//false console.log(man1.say === man2.say);//true man1.say(); //hello, my name is joe
要注意的是man1和man2的實例屬性其實是覆蓋了原型屬性,但是並沒要覆蓋掉原型上的say方法(因為它們沒有),所以這裡man1.say === man2.say依然返回true,因而需要十分小心沒有覆寫掉的原型屬性,因為它是所有實例共有的。
4.寄生組合繼承
說實話我真不知道下面的這種形式叫這名字,但是它確實是最流行,最經典的javascript的繼承方式。其實,只要明白原型物件的結構即可:
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man(name, age) { Person.apply(this, arguments); } Man.prototype = Object.create(Person.prototype);//a. Man.prototype.constructor = Man;//b. var man1 = new Man('pursue'); var man2 = new Man('joe'); console.log(man1.say == man2.say); console.log(man1.name == man2.name);
其實寄生組合繼承和上面的組合繼承區別僅在於構造子類原型對象的方式上(a.和b.),這裡用到了Object.creat(obj)方法,該方法會對傳入的obj物件進行淺拷貝,類似:
function create(obj){ function T(){}; T.prototype = obj; return new T(); }
因此,a.會將子類別的原型物件與父類別的原型物件進行很好的連接,而並不像一般的組合繼承那樣直接對子類別的原型進行複製(如Man.prototype = new Person();),這樣只是很暴力的在對屬性進行覆蓋。而寄生組合繼承方式則對實例屬性和原型屬性分別進行了繼承,在實作上更合理。
注意:程式碼b.並不會改變instanceof的結果,但是對於需要用到construcor的場景,這麼做更加嚴謹。
希望本文所述對大家JavaScript程式設計有所幫助。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

現今手機的效能和功能越來越強大,幾乎所有手機都配備了便利的NFC功能,方便用戶進行行動支付和身分認證。然而,有些小米14Pro的用戶可能不清楚如何啟用NFC功能。接下來,讓我詳細向大家介紹一下。小米14Pro怎麼開啟nfc功能?步驟一:打開手機的設定選單。步驟二:找到並點選「連接和分享」或「無線和網路」選項。步驟三:在連接和共享或無線和網路選單中,找到並點擊「NFC和付款」。步驟四:找到並點選「NFC開關」。一般情況下,預設是關閉的狀態。步驟五:在NFC開關頁面上,點選開關按鈕,將其切換為開啟狀

隔空滑動螢幕是華為的一項功能,在華為mate60系列中可以說是備受好評,這個功能是通過利用手機上的激光感應器和前置攝像頭的3D深感攝像頭,來完成一系列不需要觸碰螢幕的功能,比如說隔空刷抖音,但華為Pocket2該要怎麼隔空刷抖音呢?華為Pocket2怎麼隔空截圖? 1.開啟華為Pocket2的設定2、然後選擇【輔助功能】。 3.點選打開【智慧感知】。 4.打開【隔空滑動螢幕】、【隔空截圖】、【隔空按壓】開關就可以了。 5.使用的時候,需要再距離螢幕20~40CM處,張開手掌,待螢幕上出現手掌圖標,

iPhone16Pro的CAD檔案已經曝光,設計與先前的傳聞一致。去年秋天,iPhone15Pro新增了Action按鈕,而今年秋天,Apple似乎計劃對這款硬體的尺寸進行微小的調整。加入Capture按鈕據傳言,iPhone16Pro可能會新增第二個新按鈕,這將是繼去年之後連續第二年增加新按鈕。傳聞指出新的Capture按鈕將被設定在iPhone16Pro的右下側,這項設計可望讓相機控制更加便捷,同時也能讓Action按鈕用於其他功能。這個按鈕將不再只是一個普通的快門按鈕。關於相機,從目前iP

WPS是我們常用的辦公室軟體,在進行長篇文章的編輯時,常常會因為字體太小而看不清楚,所以會對字體和整個文件進行調整。例如:把文件進行行距的調整,會讓整個文件變得非常清晰,我建議各位小夥伴們都要學會這個操作步驟,今天就分享給大家,具體的操作步驟如下,快來看一看!開啟要調整的WPS文字文件,在【開始】選單中找到段落設定工具欄,你會看到行距設定小圖示(如圖中紅色線圈所示)。 2.點選行距設定右下角的小倒三角形,會出現對應的行距數值,可以選擇1~3倍行距(如圖箭頭所示)。 3.或者點選滑鼠右鍵點擊段落,就會出

根據3月2日數據統計,比特幣二層網路MerlinChain總TVL已達30億美元。其中比特幣生態資產佔比達90.83%,包括價值15.96億美元的BTC以及4.04億美元的BRC-20資產等。上一個月,MerlinChain在開啟質押活動14天內,其TVL總額就已經達到了19.7億美元,超過了去年11月份上線也是最近同樣引人注目的Blast。 2月26日,MerlinChain生態內的NFT總價值超過了4.2億美元,成為除以太坊以外NFT市值最高的公鏈項目。項目簡介MerlinChain是OKX支

PHP7.2和5版本對比及優劣勢分析PHP是一種極為流行的伺服器端腳本語言,廣泛應用於Web開發。然而,PHP不斷在不同的版本中進行更新和改進,以滿足不斷變化的需求。目前,PHP7.2是最新版本,它和之前的PHP5版本相比有許多值得關注的差異和改進。在本文中,我們將對PHP7.2和PHP5版本進行對比,分析它們的優劣勢,並提供具體的程式碼範例。一、性能PH

C語言與PHP的差異及比較分析C語言和PHP都是常見的程式語言,但它們在許多方面有著明顯的差異。本文將對C語言和PHP進行比較分析,並透過具體的程式碼範例來說明它們之間的差異。一、語法和用途:C語言:C語言是一種過程導向的程式語言,主要用於系統級程式設計和嵌入式開發。 C語言的語法相對較為簡潔和底層,能夠直接操作內存,具有高效性和靈活性。 C語言強調程式設計師對程式的完全

時代的進步讓許多人收入越來越高了,平時使用的手機也會經常更換,最近小米剛推出的小米14Ultra想必用戶們都是有所了解的,性能配置非常高,能夠為用戶們提供更為舒適的流暢體驗,不過新手機難免會遇到很多不會用的功能,例如小米14UltraAI智慧擴圖怎麼使用?快來看看下面的使用教學吧!小米14UltraAI智慧擴圖怎麼使用?先打開小米14Ultra,進入相冊,選擇想要進行擴圖的圖片,進入相簿編輯選項。點選其中的裁切旋轉,點選裁切,在出現的選擇中點選智慧擴圖。最後根據你自己的需求來選擇擴圖的方式,
