天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

實現JavaScript中繼承的三種方式

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

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

  盡管child依然可以作為Child的實例使用,但此時已經丟失了實例child原有的對象構造信息。彌補該缺陷的方法如下:
復制代碼 代碼如下:
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”所示,通過顯示地指定對象構造Child的原型,強制所有的Child對象實例的構造都為Child。
二、使用apply、call方法
  由于JavaScript內置的Function對象的apply、call方法改變對象構造中“this”的上下文環境,使特定的對象實例具有對象構造中所定義的屬性、方法。
  使用apply、call繼承,在實際開發中操作HTML頁面上的DOM對象時尤為常用。如:
復制代碼 代碼如下:
  <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>

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

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

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

JavaScript技術實現JavaScript中繼承的三種方式,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 九九精品国产亚洲A片无码 九九精彩视频在线观看视频 | 新图解av吧 | 老司机亚洲精品影院 | 97精品视频在线观看 | 欧美乱妇日本无乱码特黄大片 | 91热久久免费频精品99欧美 | 秋霞电影在线观看午夜伦 | 无遮掩H黄纯肉动漫在线观看星 | 青青草原国产 | 男人吃奶摸下弄进去好爽 | 德国xxxx | 亚洲AV国产国产久青草 | 日本亚洲欧洲免费旡码 | 芒果视频看片在线观看 | 日韩精品亚洲专区在线影院 | 老板吻我下身好爽到高潮 | 秋霞特色大片18岁入口 | 日韩黄色免费 | 2019夜夜| 国产麻豆剧果冻传媒免费网站 | 免费人成在线观看视频不卡 | 日本漂亮妈妈7观整有限中 日本片bbbxxx | 999精品免费视频 | 国产精品成人免费观看 | 色偷偷爱偷偷要 | 真人美女精美小穴 | 7756短视频 | 亚洲精品久久久久久久蜜臀老牛 | 乌克兰女人与动ZOZO | 里番※琉璃全彩acg奈亚子 | 亚洲国产区中文在线观看 | 起碰免费公开97在线视频 | 精品国产成人系列 | 在线国产三级 | 狠狠色丁香婷婷久久综合 | 男人插曲女人的叫声 | 国产成人免费网站在线观看 | 国产成人片视频一区二区青青 | 色窝窝777欧美午夜精品影院 | 亚洲色欲色欲无码AV | 玉娇龙续集春雪瓶txt免费阅读 |