溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Javascript的類繼承是什么

發(fā)布時間:2021-07-21 19:50:08 來源:億速云 閱讀:133 作者:chen 欄目:web開發(fā)

本篇內(nèi)容介紹了“Javascript的類繼承是什么”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

說到Javascript類繼承,就必然離不開原型鏈,但只通過原型鏈實(shí)現(xiàn)的繼承有著不少缺陷。

無參數(shù)類繼承的問題

先看一段示例代碼,實(shí)現(xiàn)B繼承于A:

function A() {  }  A.prototype.a1 = function() {  };  function B() {  }  B.prototype = new A();  B.prototype.b1 = function() {  };  var b = new B();  alert(b.constructor == A); // true  alert(b.constructor == B); // false

這段代碼的主要問 題是:

1、需要實(shí)例化A作為B的原型,此時就執(zhí)行了A的構(gòu)造函數(shù)。但按照面向?qū)ο蟮囊?guī)則,實(shí)例化B之前,B及其父類A的構(gòu)造函數(shù)都不應(yīng)該執(zhí)行。

2、更改了B的prototype,導(dǎo)致b.constructor不是B而是A。

有參類繼承的問題

假設(shè)A和B都有兩個字符串參數(shù)s1和s2,A中計算了兩段字符串的總長度,B直接以s1、s2為參數(shù)調(diào)用A:

function A(s1, s2)   {  this.totalLength = s1.length + s2.length;  }  A.prototype.a1 = function()   {  };  function B(s1, s2)   {  }  B.prototype = new A();  B.prototype.b1 = function()   {  };  new B(“ab”, “123″);

可以看到,這段代碼中根本沒有辦法把s1和s2傳到A,而又因為實(shí)例化A作為B的原型時沒有 參數(shù),所以出現(xiàn)了異常:

s1 is undefined

解決方案

s1 和s2的作用域只在B內(nèi),要把它們傳到A,就只能在B中操作,借助函數(shù)的apply方法就可以實(shí)現(xiàn)之:

function B(s1, s2)   {  A.apply(this, arguments);  alert(this.totalLength);  }

接下來的問題就是如何把A的方法添加到B的原型中去。這也不 難,只要遍歷A.prototype,把方法復(fù)制到B.prototype即可。要注意的是,對于同名的方法,自然是子類優(yōu)先(重載), 因而不能覆蓋:

for (var m in A.prototype)   {  if (!B.prototype[m])   { // 父類不能覆蓋子類的方法  B.prototype[m] = A.prototype[m];  }  }

“Javascript的類繼承是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI