老生常談 關於JavaScript的類的繼承,老生常談javascript

來源:互聯網
上載者:User

老生常談 關於JavaScript的類的繼承,老生常談javascript

其實最一開始學JS的時候就看過繼承的實現。當時只是去試著理解從書上看來的程式碼片段而已。今天又重新思考了一下,感覺這是一個思維探索演化的結果。

繼承,即複用。

如果拋開繼承的固有思想,讓b複用a的成員,最簡單粗暴的做法, b=a;

那麼,問題來了: 對b的任何改動,就是對a的改動(同一個object嘛)。

好吧,那就拷貝一份,淺拷貝不夠安全的話,就用深拷貝。

問題:代碼是複用了,但記憶體浪費了(不管是變數還是方法,在JS中都是對象)。

不拷貝,唯讀不寫,就可以用JS的原型,b.__proto__ = a。一般我們不直接更改__proto__,太暴力了,JS中提供了一個method可以比較“溫和”地達到目的——Object.create(b)。

這個方法可行,但這隻是具體對象的複用模式,如果做到“利用ConstructorB建立的對象能複用ConstructorA的對象的原型”呢?

答案是:將b看成是ConstructorB.prototype,將a看成ConstructorA.prototype.

問題:

解決方案:

申明ConstructorB的時候,系統自動會讓ConstructorB.prototype.constructor=ConstructorB; 在上面代碼中為了複用ConstructorA.prototype, 丟掉了constructor, 補上即可。

以上是最基本的繼承,關於子類如何更通用地調用父類的建構函式及成員(如this._super),如何更通用地實現繼承模式(如A=inheritFrom(B)),等等,不在本文範圍^O^

以上就是小編為大家帶來的老生常談 關於JavaScript的類的繼承全部內容了,希望大家多多支援幫客之家~

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.