亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

理解javascript對象繼承

2019-11-20 10:15:12
字體:
來源:轉載
供稿:網友

先從一個問題進行研究深入,什么是javascript對象繼承?

比如我們有一個“動物”對象的構造函數。

  function animal() {    this.type = '動物';  }

還有一個“貓”對象的構造函數。

  function cat(name,color) {    this.name = name;    this.color = color;  }

我們知道貓也屬于動物,如果這個貓對象想要繼承動物對象的屬性,我們該怎么做呢?

構造函數綁定
使用構造函數綁定是最簡單的方法,使用call或者apply將父對象綁定在自對象上就可以了。

 function cat(name,color) {    animal.apply(this,arguments);    this.name = name;    this.color = color;  }  var cat1 = new cat("haha", 'red');  console.log(cat1.type); //動物

不過這種方法比較少見。

拷貝繼承
如果把父對象的所有屬性和方法,拷貝進子對象,也可以實現繼承。

  function extend(Child, Parent) {    var p = Parent.prototype;    var c = Child.prototype;    for (var i in p) {      c[i] = p[i];      }    c.uber = p;   //橋梁作用  }

使用方法:

 extend(cat, animal);  var cat1 = new cat("haha","red");  alert(cat1.type);   // 動物

原型繼承(prototype)
相比于上面的直接綁定,原型繼承的方法比較常見,對于prototype,我自己簡單總結了一下。

每個函數都有一個prototype屬性,這個屬性是指向一個對象的引用,當使用new關鍵字創建新實例的時候,這個實例對象會從原型對象上繼承屬性和方法。

也就是說,如果將“貓”構造函數的prototype屬性指向一個“動物”實例,那么再創建“貓”對象實例的時候,就繼承了“動物”對象的屬性和方法了。

繼承實例

 cat.prototype = new animal();  cat.prototype.constructor = cat;  var cat1 = new cat("haha","red");  console.log(cat1.constructor == cat);  //true  console.log(cat1.type); // 動物

1、代碼第一行,我們將cat函數的prototype對象指向一個animal對象的實例(其中就包含了animal的type屬性了)。

2、代碼第二行是什么意思呢?

1)、首先,假如我們沒有加這行代碼,運行

    cat.prototype = new animal();
    console.log(cat.prototype.constructor == animal);  //true
也就是說,其實每個prototype對象都有一個constructor屬性,指向它的構造函數。

2)、我們再看下面的代碼

 cat.prototype = new animal();  var cat1 = new cat("haha", 'red');  console.log(cat1.constructor == animal);  //true

由上我們看到實例cat1的構造函數是animal,所以,顯然是不對的。。。cat1明明是new cat()才生成的,所以我們應該手動糾正。cat.prototype對象的constructor值改為cat。

3)、所以這也是我們應該注意的一點,如果我們替換了prototype對象,就應該手動糾正prototype對象的constructor屬性。

    o.prototype = {};
    o.prototype.constructor = o;
直接繼承prototype
由于在animal對象中,不變的屬性可以直接寫在animal.prototype中。然后直接讓cat.prototype指向animal.prototype也就實現了繼承。

現在我們先將animal對象改寫成:

  function animal() {  }  animal.prototype.type = '動物';

然后再實現繼承:

 cat.prototype = animal.prototype;  cat.prototype.constructor = cat;  var cat1 = new cat("haha","red");  console.log(cat1.type); // 動物

與上一種方法相比,這種方法顯得效率更高(沒有創建animal實例),節省了空間。但是這樣做正確嗎?答案是不正確,我們繼續看。

    cat.prototype = animal.prototype;
這行代碼讓cat.prototype和animal.prototype指向了同一個對象,所以如果改變了cat.prototype的某一個屬性,都會反映到animal.prototype上,這顯然不是我們想要看到的。

比如我們運行:

    console.log(animal.prototype.constructor == animal)  //false
結果看到是false,為什么呢?cat.prototype.constructor = cat;這一行就會把animal.prototype的constructor屬性也改掉了。

利用空對象作為中介

  var F = function(){};  F.prototype = animal.prototype;  cat.prototype = new F();  cat.prototype.constructor = cat;

結合上面兩種方法,因為F是空對象,所以幾乎不占內存。這時修改cat的prototype對象,就不會影響到animal的prototype對象。

    console.log(animal.prototype.constructor == animal);   // true
然后我們將上面的方法封裝一下:

  function extend(Child, Parent) {    var F = function(){};    F.prototype = Parent.prototype;    Child.prototype = new F();    Child.prototype.constructor = Child;    Child.uber = Parent.prototype;  }

使用的時候,方法如下:  

 extend(cat,animal);  var cat1 = new cat("haha","red");  console.log(cat1.type); // 動物

Child.uber = Parent.prototype; 這行代碼就是個橋梁作用,讓子對象的uber屬性直接指向父對象的prototype屬性,等于在自對象上打開一條叫uber的通道,讓子對象的實例能夠使用父對象的所有屬性和方法。

以上就是對javascript對象繼承我的理解,希望或多或少能夠幫助到大家,謝謝大家的閱讀。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美一性一乱一交一视频| 国产欧美日韩综合精品| 亚洲片国产一区一级在线观看| 91chinesevideo永久地址| 色琪琪综合男人的天堂aⅴ视频| 97国产精品人人爽人人做| 欧美午夜视频一区二区| 国产亚洲一级高清| 精品国产欧美成人夜夜嗨| 亚洲第一区中文字幕| 欧美性xxxx极品高清hd直播| 中文字幕九色91在线| 国产精品久久91| 色综合天天狠天天透天天伊人| 国产精品午夜一区二区欲梦| 亚洲精品影视在线观看| 91国自产精品中文字幕亚洲| 亚洲欧美国产精品va在线观看| 最近更新的2019中文字幕| 韩国视频理论视频久久| 色悠悠久久88| 日韩二区三区在线| 亚洲视频999| 福利微拍一区二区| 国产va免费精品高清在线观看| 久久午夜a级毛片| 久久久久久久久久久av| 亚洲性夜色噜噜噜7777| 欧美一级电影久久| 亚洲女性裸体视频| 狠狠操狠狠色综合网| 久久艳片www.17c.com| 国产成人鲁鲁免费视频a| 久久久久久久久中文字幕| 亚洲国产精品一区二区久| 中文字幕欧美在线| 国外成人免费在线播放| 亚洲日本欧美中文幕| 国产精品久久久久77777| 久久国产精品久久久久久久久久| 欧洲s码亚洲m码精品一区| 久久欧美在线电影| 久久91亚洲精品中文字幕| 欧美高清视频免费观看| 热久久99这里有精品| 欧美激情免费观看| 亚洲片在线观看| 2019亚洲日韩新视频| 久久国产精品偷| 456亚洲影院| 欧美视频13p| 国产精品久久久久久一区二区| 色香阁99久久精品久久久| 91影视免费在线观看| 国产精品老女人视频| 久久久久久久爱| 一区二区三区视频免费在线观看| 欧美在线一区二区三区四| 最新69国产成人精品视频免费| 97精品伊人久久久大香线蕉| zzijzzij亚洲日本成熟少妇| 一区二区中文字幕| 亚洲成人免费网站| 97在线视频精品| 中文字幕精品一区二区精品| 日韩av大片免费看| 成人免费视频网| 欧美精品成人91久久久久久久| 欧美影院在线播放| 国产乱肥老妇国产一区二| 奇门遁甲1982国语版免费观看高清| 日韩a**中文字幕| 亚洲欧美福利视频| 欧美主播福利视频| 粗暴蹂躏中文一区二区三区| 亚洲激情视频网| 亚洲女人被黑人巨大进入| 欧美性xxxx极品高清hd直播| 国自产精品手机在线观看视频| 麻豆乱码国产一区二区三区| 成人亚洲综合色就1024| 国内精品久久久久影院 日本资源| 懂色av影视一区二区三区| 姬川优奈aav一区二区| 狠狠色狠狠色综合日日小说| 国模私拍一区二区三区| 欧美午夜性色大片在线观看| 欧美日韩免费观看中文| 欧美性jizz18性欧美| 欧美一级在线亚洲天堂| 国产精品夫妻激情| 国产一区二区三区在线观看网站| 欧美性xxxxx极品| 国产91精品久久久久久久| 日韩欧美在线视频免费观看| 538国产精品视频一区二区| 国产精品视频久久久| 日韩精品高清在线观看| 国产精品免费久久久久影院| 亚洲天堂av女优| 日韩免费中文字幕| 欧美在线亚洲在线| 伊人精品在线观看| 国内精品模特av私拍在线观看| 欧美激情久久久| 亚洲欧美一区二区三区四区| 久久精品国产免费观看| 日韩欧美999| 麻豆成人在线看| 成人天堂噜噜噜| 欧美又大粗又爽又黄大片视频| 国产精品一区二区女厕厕| 欧美日韩国产一区在线| 欧美日韩国产丝袜另类| 亚洲成av人影院在线观看| 中文字幕精品一区二区精品| 国产精品中文字幕久久久| 亚洲第一网站免费视频| 国语自产精品视频在线看抢先版图片| 国产成人av网址| 久久久久久国产精品美女| 久久欧美在线电影| 亚洲精品国产精品国自产观看浪潮| 亚洲香蕉成视频在线观看| 日韩av资源在线播放| 92看片淫黄大片欧美看国产片| 欧美丝袜美女中出在线| 欧美成人合集magnet| 久久久亚洲影院| 亚洲成人在线网| 欧美老妇交乱视频| 久久久久久久久久久免费| 久久福利网址导航| 91免费综合在线| 国产亚洲a∨片在线观看| 成人欧美一区二区三区在线| 亚洲午夜精品久久久久久性色| 亚洲2020天天堂在线观看| 91成人天堂久久成人| 日韩成人小视频| 欧美亚洲成人网| 日韩在线观看视频免费| 亚洲第一中文字幕| 在线观看欧美日韩国产| 91夜夜未满十八勿入爽爽影院| 欧美极品在线播放| 成人免费大片黄在线播放| 中文字幕亚洲情99在线| 亚洲精品999| 日韩成人中文字幕| 久久久久在线观看| 国产精品露脸av在线| 亚洲人成免费电影| 亚洲色图第三页| 亚洲精品aⅴ中文字幕乱码| 日韩一区二区三区xxxx| 少妇高潮久久77777| 欧美精品一区三区| 精品美女永久免费视频| 日韩的一区二区| 国产精品久久99久久| 高清欧美电影在线| 亚洲视频电影图片偷拍一区| 午夜欧美大片免费观看|