欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js常用的繼承--組合式繼承

 更新時(shí)間:2017年03月06日 17:02:57   作者:fantasy525  
本篇文章主要介紹了js常用的繼承--組合式繼承的相關(guān)知識(shí),具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧

組合繼承有時(shí)候也叫偽經(jīng)典繼承,指的是將原型鏈和借用構(gòu)造函數(shù)技術(shù)組合到一塊,從而發(fā)揮二者之長(zhǎng)的一種繼承模式,其背后的思路是使用原型鏈實(shí)現(xiàn)對(duì)原型屬性和方法的繼承,而通過(guò)借用構(gòu)造函數(shù)來(lái)實(shí)現(xiàn)對(duì)實(shí)例屬性的繼承。這樣既通過(guò)在原型上定義方法實(shí)現(xiàn)了函數(shù)復(fù)用,又能保證每個(gè)實(shí)例都有它的自己的屬性。

 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);
  this.age=age;
 }
 SubType.prototype=new SuperType();
 SubType.prototype.constructor=SubType;
 SubType.prototype.sayAge=function(){
  console.log(this.age);
 }
 var instance1=new SubType("zxf",24);
 instance1.colors.push("black");
 console.log(instance1.colors);//["red","blue","green","black"]
 instance1.sayName();//"zxf"
 instance1.sayAge();//24
 var instance2=new SubType("jay",36);
 console.log(instance2.colors);//["red","blue","green"]
 instance2.sayName();//"jay"
 instance2.sayAge();//36

在這個(gè)例子中,supertype構(gòu)造函數(shù)定義了兩個(gè)屬性,name和colors。supertype的原型定義了一個(gè)方法sayname()。subtype構(gòu)造函數(shù)調(diào)用supertype時(shí)傳入了name參數(shù),緊接著又定義了它自己的屬性age。然后將supertype的實(shí)例賦值給subtype的原型,然后又在該新原型上定義了方法sayage()。這樣一來(lái),就可以讓兩個(gè)不同的subtype實(shí)例既可以擁有屬性--包括colors屬性,又可以使用相同的方法。

組合式繼承缺點(diǎn)是:調(diào)用了兩次supertype構(gòu)造函數(shù),一次在賦值subtype的原型時(shí),一次在實(shí)例化子類(lèi)時(shí)call調(diào)用,這次調(diào)用會(huì)屏蔽原型中的兩個(gè)同名屬性。

參考書(shū)籍:Javascript高級(jí)程序設(shè)計(jì)(第3版);

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • JavaScript實(shí)現(xiàn)按Ctrl鍵打開(kāi)新頁(yè)面

    JavaScript實(shí)現(xiàn)按Ctrl鍵打開(kāi)新頁(yè)面

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)按Ctrl鍵打開(kāi)新頁(yè)面的例子,本文方法適用HTML5環(huán)境中,需要的朋友可以參考下
    2014-09-09
  • JavaScript獲取GridView選擇的行內(nèi)容

    JavaScript獲取GridView選擇的行內(nèi)容

    一般GridView第一列是多選框CheckBox,負(fù)責(zé)標(biāo)記當(dāng)前行是否被選中,后面可以有文本框TextBox,下拉框DropDownList,標(biāo)簽Lable
    2009-04-04
  • 固定表格行列(expression)在IE下適用

    固定表格行列(expression)在IE下適用

    本文為大家介紹下使用expression固定表格行列,這是一種在IE下適用的固定行列的方法,感興趣的朋友可以學(xué)習(xí)下,希望對(duì)大家有所幫助
    2013-07-07
  • Promise拋出錯(cuò)誤解決基礎(chǔ)示例詳解

    Promise拋出錯(cuò)誤解決基礎(chǔ)示例詳解

    這篇文章主要為大家介紹了Promise拋出錯(cuò)誤解決基礎(chǔ)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • JS實(shí)現(xiàn)點(diǎn)擊按鈕后框架內(nèi)載入不同網(wǎng)頁(yè)的方法

    JS實(shí)現(xiàn)點(diǎn)擊按鈕后框架內(nèi)載入不同網(wǎng)頁(yè)的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)點(diǎn)擊按鈕后框架內(nèi)載入不同網(wǎng)頁(yè)的方法,涉及javascript點(diǎn)擊按鈕載入頁(yè)面的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-05-05
  • js 走馬燈簡(jiǎn)單實(shí)例

    js 走馬燈簡(jiǎn)單實(shí)例

    這篇文章主要介紹了js 走馬燈簡(jiǎn)單實(shí)例,有需要的朋友可以參考一下
    2013-11-11
  • 怎么使用js計(jì)算當(dāng)前一周的日期

    怎么使用js計(jì)算當(dāng)前一周的日期

    這篇文章主要給大家介紹了關(guān)于怎么使用js計(jì)算當(dāng)前一周的日期的相關(guān)資料,我們可以使用JavaScript的Date對(duì)象來(lái)獲取近一周的日期,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下
    2023-09-09
  • 關(guān)于RequireJS的簡(jiǎn)單介紹即使用方法

    關(guān)于RequireJS的簡(jiǎn)單介紹即使用方法

    下面小編就為大家?guī)?lái)一篇關(guān)于RequireJS的簡(jiǎn)單介紹即使用方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • JS阻止事件冒泡行為和閉包的方法

    JS阻止事件冒泡行為和閉包的方法

    這篇文章主要介紹了JS阻止事件冒泡行為和閉包的方法的相關(guān)資料,需要的朋友可以參考下
    2016-06-06
  • js編寫(xiě)貪吃蛇的小游戲

    js編寫(xiě)貪吃蛇的小游戲

    本文為大家介紹的是使用JS寫(xiě)的貪吃蛇游戲,個(gè)人練習(xí)之用,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望對(duì)大家學(xué)習(xí)js有所幫助
    2015-12-12

最新評(píng)論