中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

javascript的幾種繼承方法介紹
來源:易賢網 閱讀:1113 次 日期:2016-07-19 13:57:57
溫馨提示:易賢網小編為您整理了“javascript的幾種繼承方法介紹”,方便廣大網友查閱!

下面小編就為大家帶來一篇javascript的幾種繼承方法介紹。小編覺得挺不錯的。現在分享給大家,給大家一個參考

1.原型鏈繼承:構造函數、原型和實例的關系:每個構造函數都有一個原型對象,原型對象都包含一個指向構造函數的指針,而實例都包含一個指向原型對象的內部指針。確認原型和實例之間的關系用instanceof。

原型鏈繼承缺點:字面量重寫原型會中斷關系,使用引用類型的原型,并且子類型還無法給超類型傳遞參數

function Parent(){

    this.name='mike';

  }

  function Child(){

    this.age=12;

  }

  //兒子繼承父親(原型鏈)

  Child.prototype=new Parent();//Child繼承Parent,通過原型形成鏈條

  var test=new Child();

  console.log(test.age);

  console.log(test.name);//得到被繼承的屬性

  //孫子繼續原型鏈繼承兒子

  function Brother(){

    this.weight=60;

  }

  Brother.prototype=new Child();//繼承原型鏈繼承

  var brother=new Brother();

  console.log(brother.name);//繼承了Parent和Child,彈出mike

  console.log(brother.age);//12

  console.log(brother instanceof Child);//ture

  console.log(brother instanceof Parent);//ture

  console.log(brother instanceof Object);//ture

2.構造函數實現繼承:又叫偽造對象或經典繼承。

構造函數實現繼承缺點:借用構造函數雖然解決了原型鏈繼承的兩種問題,但沒有原型,則復用無從談起,所以需要原型鏈+借用構造函數模式。

function Parent(age){

    this.name=['mike','jack','smith'];

    this.age=age;

  }

  function Child(age){

    Parent.call(this,age);//把this指向Parent,同時還可以傳遞參數

  }

  var test=new Child(21);

  console.log(test.age);//21

  console.log(test.name);

  test.name.push('bill');

  console.log(test.name);//mike,jack,smith,bill

3.組合繼承:使用原型鏈實現對原型屬性和方法的繼承,而通過借用構造函數來實現對實例屬性的繼承。這樣即通過在原型上定義方法實現了函數復用,又保證每個實現都有它自己的屬性。

缺點:無論什么情況下,都會調用兩次超類型構造函數,一次是在創建子類型原型的時候,另一次是在創建子類型原型的時候,另一次是在子類型構造函數內部。

function Parent(age){

    this.name=['mike','jack','smith'];

    this.age=age;

  }

  Parent.prototype.run=function(){

    return this.name+' are both '+this.age;

  }

  function Child(age){

    Parent.call(this,age);//給超類型傳參,第二次調用

  }

  Child.prototype=new Parent();//原型鏈繼承,第一次調用

  var test1=new Child(21);//寫new Parent(21)也行

  console.log(test1.run());//mike,jack,smith are both 21

  var test2=new Child(22);

  console.log(test2.age);

  console.log(test1.age);

  console.log(test2.run());

  //這樣可以使test1和test2分別擁有自己的屬性age同時又可以有run方法

4.原型式繼承:借助原型可以基于已有的對象創建新對象,同時還不必因此創建自定義類型。它要求必須有一個對象可以作為另一個對象的基礎。

function object(o){

    function F(){};

    F.prototype=o;

    return new F();

  }

  var person={

    name:'nicho',

    friends:['shell','jim','lucy']

  }

  var anotherPerson = object(person);

  anotherPerson.name = 'Greg';

  anotherPerson.friends.push('Rob');

  console.log(anotherPerson.friends);//["shell", "jim", "lucy", "Rob"]

  var yetAnotherPerson = object(person);

  yetAnotherPerson.name = 'Linda';

  yetAnotherPerson.friends.push('Barbie');

  console.log(yetAnotherPerson.friends);//["shell", "jim", "lucy", "Rob", "Barbie"]

  console.log(person.friends);//["shell", "jim", "lucy", "Rob", "Barbie"]

ECMAScript5通過新增Object.create()方法規范化了原型式繼承,這個方法接收兩個參數:一個用作新對象原型的對象和(可選的)一個為新對象定義屬性的對象。

var person2={

    name:'nicho',

    friends:['shell','jim','lucy']

  };

  var anoP2=Object.create(person2);

  anoP2.name="Greg";

  anoP2.friends.push('Rob');

  console.log(anoP2.friends);//["shell", "jim", "lucy", "Rob"]

  var yetP2=Object.create(person2);

  yetP2.name="Linda";

  yetP2.friends.push('Barbie');

  console.log(yetP2.friends);//["shell", "jim", "lucy", "Rob", "Barbie"]

  console.log(person2.friends);//["shell", "jim", "lucy", "Rob", "Barbie"]

  /*以這種方式指定的任何屬性都會覆蓋原型對象上的同名屬性。*/

  var threeP=Object.create(person,{

    name:{value:'red'}

  });

  console.log(threeP.name);//red,如果threeP中無name則輸出person2里的name值nicho

5.寄生式繼承:思路與寄生構造函數和工廠模式類似,即創建一個僅用于封裝繼承過程的函數,該函數在內部以某種方式來增強對象,最后再像真地是它做了所有工作一樣返回對象。

function object(o){

    function F(){};

    F.prototype=o;

    return new F();

  };

  function createAnother(o){

    var cl=object(o);

    cl.sayHi=function(){

      console.log('hi');

    }

    return cl;

  };

  var person={

    name:'nick',

    friends:['shelby','court','van']

  }

  var anotherPerson=createAnother(person);

  anotherPerson.sayHi();//hi

  console.log(anotherPerson.name);//nick

  console.log(anotherPerson.friends);//["shelby", "court", "van"]

  /*這個例子中的代碼基于 person 返回了一個新對象—— anotherPerson 。 新對象不僅具有 person

   的所有屬性和方法,而且還有自己的 sayHi() 方法*/

寄生組合式繼承:無論什么情況下,都會調用兩次超類型構造函數,一次是在創建子類型原型的時候,另一次是在創建子類型原型的時候,另一次是在子類型構造函數內部,這樣子類型最終會包含超類型對象的全部實例屬性,我們不得不在調用子類型構造函數時重寫這些屬性。因此出現了寄生組合式繼承。

6.寄生組合式繼承:借用構造函數來繼承屬性,通過原型鏈的混成形式來繼承方法。基本思路:不必為了指定子類型的原型而調用超類型的構造函數。本質上就是使用寄生式繼承來繼承超類型的原型,然后再將結果指定給子類型的原型。

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;

  }

  function object(o){

    function F(){};

    F.prototype=o;

    return new F();

  };

  /*inheritPrototype此函數第一步是創建超類型原型的一個副本。第二步是為創建的副本添加constructor屬性,

  * 從而彌補因重寫原型而失去的默認的constructor屬性,第三步將新創建的對象(副本)賦值給子類型的原型*/

  function inheritPrototype(subType,superType){

    var prototype=object(superType.prototype);//創建對象

    prototype.constructor=subType;//增強對象

    subType.prototype=prototype;//指定對象

  }

  inheritPrototype(SubType,SuperType);

  SubType.prototype.sayAge=function(){

    console.log(this.age);

  }

  var p=new SubType('xiaoli',24);

  console.log(p.sayName());

  console.log(p.sayAge());

  console.log(p.colors)

此方法優點:只調用了一次父類SuperType構造函數,并且因此避免了在SubType.prototype上面創建不必要的多余的屬性。同時原型鏈還能保持不變,還能正常使用instanceof和isPrototypeOf();

以上這篇javascript的幾種繼承方法介紹就是小編分享給大家的全部內容了,希望能給大家一個參考

更多信息請查看網絡編程
易賢網手機網站地址:javascript的幾種繼承方法介紹
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
夜夜爽av福利精品导航| 亚洲国产欧美久久| 久久国产综合精品| 久久综合影音| 国产精品国产成人国产三级| 国产精品热久久久久夜色精品三区| 欧美午夜一区二区福利视频| 国产亚洲欧美一级| 一区二区三区蜜桃网| 久热精品视频在线免费观看| 国产精品久久久久久亚洲毛片 | 欧美大片18| 黄色亚洲在线| 欧美精品亚洲精品| 亚洲男人的天堂在线| 韩国成人福利片在线播放| 欧美va天堂va视频va在线| 亚洲视频一区二区免费在线观看| 国产亚洲成人一区| 欧美 日韩 国产精品免费观看| 国产精品99久久久久久白浆小说| 国产精品网站在线播放| 欧美日韩中文| 欧美在线啊v| 在线亚洲一区| 在线精品一区| 欧美视频久久| 亚洲激情午夜| 嫩模写真一区二区三区三州| 狠狠色综合色区| 久久成人精品无人区| 国产精品亚洲产品| 亚洲免费网址| 国产精品素人视频| 久久精品一区中文字幕| 国产三级欧美三级| 欧美日韩大片| 欧美激情久久久| 另类综合日韩欧美亚洲| 欧美一区二区视频在线观看| 在线综合亚洲| 亚洲精品一线二线三线无人区| 激情久久一区| 黄色亚洲精品| 国产一区二区三区久久久| 国产精品videosex极品| 欧美日韩国产精品专区| 蜜臀91精品一区二区三区| 久久国产88| 久久精品九九| 久久久久天天天天| 久久久亚洲精品一区二区三区| 欧美一区二区三区四区高清 | 精品白丝av| 国产午夜亚洲精品理论片色戒| 国产精品一区二区你懂得 | 欧美一区二区三区免费在线看| 亚洲视频每日更新| 亚洲欧美日韩一区| 亚洲欧美综合另类中字| 亚洲欧美一区二区三区极速播放| 亚洲图片欧美一区| 午夜精品久久| 欧美一区二区三区在线观看视频| 午夜精品久久久久久久久久久久| 亚洲午夜伦理| 欧美一区二区三区在线播放| 欧美一级播放| 久久蜜桃精品| 亚洲欧美在线观看| 亚洲激情成人| 国产一区久久久| 欧美婷婷久久| 另类尿喷潮videofree| 欧美电影免费观看高清| 亚洲一区二区成人在线观看| 伊人久久久大香线蕉综合直播| 欧美日韩色综合| 久热精品视频| 国产精品劲爆视频| 国产一区三区三区| 亚洲精品中文字幕有码专区| 在线亚洲美日韩| 欧美一区二区三区视频| 久久婷婷麻豆| 欧美性大战久久久久| 国产一区亚洲一区| 亚洲国产精品久久久久| 99香蕉国产精品偷在线观看| 欧美伊人久久久久久午夜久久久久| 久久久亚洲欧洲日产国码αv | 国产精品视频网址| 狠狠色丁香久久婷婷综合_中| 亚洲欧美日韩综合| 一区二区三区在线高清| 国产一区二区毛片| 国产欧美va欧美va香蕉在| 国产精品草草| 国产精品久久网站| 国产精品欧美一区喷水 | 一区二区三区精品国产| 尤物九九久久国产精品的特点| 国产日韩欧美一区二区三区在线观看 | 欧美一区91| 亚洲女同精品视频| 亚洲欧美日韩另类精品一区二区三区| 日韩亚洲在线| 亚洲免费不卡| 亚洲男人的天堂在线aⅴ视频| 欧美天堂亚洲电影院在线播放| 国产精品护士白丝一区av| 一区二区在线观看视频| 一区二区欧美精品| 老色鬼久久亚洲一区二区| 欧美吻胸吃奶大尺度电影| 精品不卡在线| 亚洲欧美视频在线观看| 欧美精品激情| 亚洲第一免费播放区| 久久精品青青大伊人av| 国产精品视频久久| 亚洲欧美在线视频观看| 欧美国产日韩一区二区三区| 国模私拍视频一区| 免费不卡视频| 老**午夜毛片一区二区三区| 亚洲一区二区三区精品在线观看| 影音先锋成人资源站| 国模精品一区二区三区色天香| 国产精品v亚洲精品v日韩精品| 国产精品丝袜xxxxxxx| 国产视频久久网| 欧美日韩精品一区二区天天拍小说 | 欧美啪啪成人vr| 免费看亚洲片| 欧美视频免费看| 国产美女精品一区二区三区| 欧美一区二区三区四区夜夜大片| 99精品欧美一区二区蜜桃免费| 夜夜嗨av一区二区三区免费区 | 欧美理论片在线观看| 欧美偷拍另类| 亚洲电影免费在线 | 欧美乱人伦中文字幕在线| 国产精品mm| 亚洲国内欧美| 久久丁香综合五月国产三级网站| 欧美精品午夜视频| 国内精品视频666| 亚洲香蕉视频| 欧美久久久久久| 极品尤物一区二区三区| 亚洲深夜av| 欧美激情性爽国产精品17p| 国产一区二区高清视频| 亚洲淫片在线视频| 另类专区欧美制服同性| 午夜在线视频观看日韩17c| 国产丝袜美腿一区二区三区| 久久精品三级| 91久久综合| 国产精品三区www17con| 欧美黄污视频| 亚洲自拍16p| 在线看片第一页欧美| 欧美午夜剧场| 久久久噜噜噜久久中文字幕色伊伊 | 久久亚洲国产精品一区二区| 亚洲国产成人久久综合一区| 欧美日韩国产成人| 欧美在线观看www| 在线免费日韩片| 欧美日韩在线一区二区| 欧美在线观看视频| 亚洲人精品午夜在线观看| 国产精品网站在线| 牛人盗摄一区二区三区视频| 亚洲午夜精品久久久久久浪潮| 国产日韩一区二区| 欧美日韩精品久久久| 久久嫩草精品久久久精品| 中日韩视频在线观看| 怡红院精品视频| 国产精品激情偷乱一区二区∴| 麻豆九一精品爱看视频在线观看免费| 亚洲视频高清| 亚洲片区在线| 在线观看av一区| 国产精品影视天天线| 欧美人与禽猛交乱配视频| 久久久噜噜噜久久狠狠50岁| 亚洲免费一级电影| 一区二区激情视频| 亚洲精品一区二区三区四区高清 | 国产欧美日韩亚洲| 欧美日韩国产一级| 欧美.www| 欧美+亚洲+精品+三区| 欧美aaa级| 亚洲另类视频|