中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript借用構造函數繼承的方法

發布時間:2021-02-02 13:57:33 來源:億速云 閱讀:154 作者:小新 欄目:web開發

小編給大家分享一下JavaScript借用構造函數繼承的方法,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

借用構造函數繼承是在子類型構造函數的內部調用超類型構造函數,通過使用apply()和call()方法

function girlFriend(){
    this.girls = ['chen','wang','zhu'];
  }
  function Person(){
    girlFriend.call(this,20);
  }
  var wang = new Person();
  var zhu = new Person();
  wang.girls.push('zhang');
  console.log(wang.girls);  //(4) ["chen", "wang", "zhu", "zhang"]
  console.log(zhu.girls);    //(3) ["chen", "wang", "zhu"]

通過以上代碼,我們可以發現,在原型鏈繼承中出現的問題不再出現了,這個超類不會被子類所創建的實例共享了。

借用構造函數繼承的優勢是可以在子類型構造函數中向超類型構造函數傳遞參數,例如以下代碼:

function SuperType(name){
    this.name = name;
  }
  function SubType(){
    SuperType.call(this,"nick");
    this.age = 20;
  }
  var instance = new SubType();
  console.log(instance.name);    //nick
  console.log(instance.age);    //20

借用構造函數繼承的問題:用構造函數繼承并不能繼承到超類型原型中定義的方法,例如以下代碼,在girlFriends構造函數的原型中添加sayHello方法:

girlFriend.prototype.sayHello = function(){
    console.log('hello');
  }

繼承它的子類構造函數的實例并不能調用到這個sayHello方法,返回的值是undefined

看完了這篇文章,相信你對“JavaScript借用構造函數繼承的方法”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

余干县| 白城市| 太湖县| 五台县| 杭州市| 右玉县| 通河县| 新宾| 黄龙县| 益阳市| 安图县| 昂仁县| 漯河市| 苏尼特左旗| 三穗县| 莱阳市| 洱源县| 潞城市| 合江县| 平安县| 东乌珠穆沁旗| 平昌县| 华宁县| 芷江| 德令哈市| 阳泉市| 体育| 嘉义市| 平罗县| 武宣县| 萨嘎县| 广河县| 禄丰县| 无棣县| 郴州市| 凌源市| 巫山县| 陈巴尔虎旗| 深泽县| 巨野县| 河北区|