中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

實(shí)現(xiàn)JavaScript中繼承的三種方式

一、原型鏈繼承
  在原型鏈繼承方面,JavaScript與Java、c#等語(yǔ)言類(lèi)似,僅允許單父類(lèi)繼承。prototype繼承的基本方式如下:
復(fù)制代碼 代碼如下:
function Parent(){}
function Child(){}
Child.prototype = new Parent();

  通過(guò)對(duì)象Child的prototype屬性指向父對(duì)象Parent的實(shí)例,使Child對(duì)象實(shí)例能通過(guò)原型鏈訪問(wèn)到父對(duì)象構(gòu)造所定義的屬性、方法等。
  構(gòu)造通過(guò)原型鏈鏈接了父級(jí)對(duì)象,是否就意味著完成了對(duì)象的繼承了呢?答案是否定的。如:
復(fù)制代碼 代碼如下:
function Parent(){}
function Child(){}
Child.prototype = new Parent();
var child = new Child();
alert(child.constructor);//function Parent(){}
alert(child instanceof Child);//true

  盡管child依然可以作為Child的實(shí)例使用,但此時(shí)已經(jīng)丟失了實(shí)例child原有的對(duì)象構(gòu)造信息。彌補(bǔ)該缺陷的方法如下:
復(fù)制代碼 代碼如下:
function Parent(){}
function Child(){}
Child.prototype = new Parent();
Child.prototype.constructor = Child;
var child = new Child();
alert(child.constructor);//function Parent(){}
alert(child instanceof Child);//true

  如上代碼片段“Child.prototype.constructor = Child”所示,通過(guò)顯示地指定對(duì)象構(gòu)造Child的原型,強(qiáng)制所有的Child對(duì)象實(shí)例的構(gòu)造都為Child。
二、使用apply、call方法
  由于JavaScript內(nèi)置的Function對(duì)象的apply、call方法改變對(duì)象構(gòu)造中“this”的上下文環(huán)境,使特定的對(duì)象實(shí)例具有對(duì)象構(gòu)造中所定義的屬性、方法。
  使用apply、call繼承,在實(shí)際開(kāi)發(fā)中操作HTML頁(yè)面上的DOM對(duì)象時(shí)尤為常用。如:
復(fù)制代碼 代碼如下:
  <div id="extend">apply,call繼承</div>
  <script language="Javascript">
  function ext()
  {
     this.onclick=function(){alert(this.innerHTML)}
  }
  ext.apply(document.getElementById("extend"));
  ext.call(document.getElementById("extend"));
  </script>

  通過(guò)apply或call定義的ext方法,使ext方法內(nèi)部的this上下文表示為DOM對(duì)象“<div id="extend">apply,call繼承</div>”。
  值得注意的是,當(dāng)使用apply、call時(shí),會(huì)直接執(zhí)行對(duì)象構(gòu)造所定義的代碼段,如:
復(fù)制代碼 代碼如下:
  <script language="Javascript">
  function testExec()
  {
     alert("執(zhí)行!");
  }
  testExec.call(null);//彈出execute對(duì)話框
  testExec.apply(null);//彈出execute對(duì)話框
  </script>

三、對(duì)象實(shí)例間的繼承
  JavaScript對(duì)象的多態(tài)性,允許實(shí)例動(dòng)態(tài)地添加屬性、方法。該特性造就了JavaScript中的另一種繼承手法――對(duì)象實(shí)例間的繼承。如:
復(fù)制代碼 代碼如下:
  var Person = {name:"nathena",age:"26"};
  var nathena = {sex:"male"};
  (function inlineExtends(so,po)
  {
    for (var i in po)
    {
      if (so[i])//如果so也具有這個(gè)成員
        continue;
      so[i] = po[i];
    }
  })(nathena,Person);
  alert(nathena.name);//返回nathana

  如以上代碼所示,在對(duì)象的實(shí)例間繼承中,父對(duì)象Persong定義了“人”所具有的共同屬性name、age,子對(duì)象nathena定義了自己的私有屬性“sex”。函數(shù)inlineExtends的功能是,為子對(duì)象nathena復(fù)制父對(duì)象Person中定義的“人”所具有的共同屬性。
  其中特別需要注意的語(yǔ)句是“if (so[i])”,此句確保了子對(duì)象原有的成員不被父對(duì)象中同名的成員所覆蓋,而違背面向?qū)ο笾懈缸訉?duì)象之間繼承的原則――子對(duì)象可以覆蓋、重載父對(duì)象的屬性或方法,父對(duì)象僅能對(duì)子對(duì)象隱藏自己的屬性或方法。

JavaScript技術(shù)實(shí)現(xiàn)JavaScript中繼承的三種方式,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲激情综合 | 亚洲午夜精品一区二区三区他趣 | 免费成人高清在线视频 | 久精品久久 | 婷婷五月色综合香五月 | 亚洲国产欧美国产综合一区 | 久久久久久天堂 | 日本一二区视频 | 亚洲国产高清高潮精品美女 | 久久综合一区二区 | 3级毛片 | 久久精品中文字幕 | 久久新 | 国产资源网| 日本三级网站在线 | 成人午夜电影在线观看 | 午夜精品视频一区 | 国产高清视频 | 先锋资源吧 | 亚洲高清电影 | 免费看啪啪网站 | 精品毛片 | 久久精品屋 | 伊人久久综合 | 午夜日韩视频 | 一道本视频 | 精品久久久久久久 | 久久久综合久久 | 精品乱码一区二区三四区 | 成人在线免费视频 | jav成人av免费播放 | 欧美视频中文字幕 | 一区二区国产精品 | 欧美综合一区二区三区 | 欧美日韩视频在线 | 日韩羞羞 | 国产精品久久国产精品 | 亚洲欧美精品在线观看 | 成人欧美一区二区三区 | 国产高清一区二区三区 | 九九色综合 |