• <center id="sm46c"></center>
  • <dfn id="sm46c"></dfn>
  • <strike id="sm46c"></strike>
  • <cite id="sm46c"><source id="sm46c"></source></cite>
    • <strike id="sm46c"><source id="sm46c"></source></strike>
      <option id="sm46c"></option>
      国产精品天天看天天狠,女高中生强奷系列在线播放,久久无码免费的a毛片大全,国产日韩综合av在线,亚洲国产中文综合专区在,特殊重囗味sm在线观看无码,中文字幕一区二区三区四区在线,无码任你躁久久久久久老妇蜜桃

      js學習中的總結——幾種繼承模式

      2018-6-29    seo達人

      如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

           js中構造函數的幾種繼承模式淺析

      一、原型鏈模式繼承

          利用原型讓一個引用類型繼承另一個引用類型的屬性和方法 。

          用的最多。

          缺點:不可傳參,不可多繼承。

      
              
      1. function People(name, age) {//添加公有屬性
      2. name = name || 'xiaolan';
      3. age = age || 18;
      4. this.name = name;
      5. this.age = age;
      6. }//創建一個名為People的類
      7. People.prototype.eat = function() {//添加私有屬性
      8. console.log(this.name + '賊能吃');
      9. }
      10. function Cat(color) {//創建一個名為Cat的類
      11. this.color = color;
      12. }
      13. Cat.prototype = new People('小叮當', 200);//實例化一個People類,并賦值給Cat類的原型鏈
      14. var cat = new Cat('藍白色')
      15. console.log(cat.name)//'小叮當'
      16. cat.eat();//'小叮當賊能吃'

      二、混合模式繼承

          用call的方法只能繼承私有屬性,所以再加一遍一遍原型鏈模式繼承,原型鏈模式繼承又把私有屬性和公有屬性都繼承了一遍。

      
              
      1. function People(name, age) { //創建一個父級People類
      2. name = name || 'xiaolan';
      3. age = age || 18;
      4. this.name = name;
      5. this.age = age;
      6. }
      7. People.prototype.eat = function() {
      8. console.log(this.name + '賊能吃');
      9. }
      10. function Cat(color, name, age) {
      11. this.color = color;
      12. People.call(this, name, age); //通過call的形式繼承
      13. //通過call(this),將People的指向改為Cat的實例
      14. }
      15. var cat = new Cat('藍白色', '小叮當', 1);
      16. console.log(cat.name);//'小叮當'
      17. cat.eat();//報錯,
      18. //繼承不了公有屬性,所以cat.eat()會報錯;

      為了繼承公有屬性,用原型鏈模式在把公有屬性和方法繼承過來,

      
              
      1. function People(name, age) { //創建一個父級People類
      2. name = name || 'xiaolan';
      3. age = age || 18;
      4. this.name = name;
      5. this.age = age;
      6. }
      7. People.prototype.eat = function() {
      8. console.log(this.name + '賊能吃');
      9. }
      10. function Cat(color, name, age) {
      11. this.color = color;
      12. People.call(this, name, age); //通過call的形式繼承
      13. //通過call(this),將People的指向改為Cat的實例
      14. }
      15. Cat.prototype = new People()
      16. var cat = new Cat('藍白色', '小叮當', 200)
      17. console.log(cat)
      18. console.log(cat.name); //'小叮當',在原型鏈繼承的時候,就近原則,cat.name 先找到'小叮當',就不往下找了
      19. cat.eat(); //'小叮當賊能吃'

      三、拷貝繼承

          優點:可以多繼承,可傳參;

          缺點:浪費資源,不能判斷父級;

      
              
      1. function People(name, age) { //創建一個父級People類
      2. name = name || 'xiaolan';
      3. age = age || 18;
      4. this.name = name;
      5. this.age = age;
      6. }
      7. People.prototype.eat = function() {
      8. console.log(this.name + '賊能吃');
      9. }
      10. function Cat(color, name, age) {
      11. this.color = color;
      12. var people = new People(name, age) //實例化一個People類
      13. for (let i in people) {
      14. this[i] = people[i]; //將people中的可枚舉屬性和方法遍歷并附給Cat類,公有屬性和私有屬性都是可枚舉屬性;
      15. }
      16. }
      17. var cat = new Cat('藍白色', '小叮當', 2);
      18. console.log(cat.name); //小叮當
      19. cat.eat(); //小叮當賊能吃

      四、寄生組合方式繼承

          優點:私有屬性和公有屬性都單獨繼承,可以傳參;

          私有屬性可以多繼承,公有屬性不可多繼承;

      
              
      1. function People(name, age) {
      2. name = name || 'xiaolan';
      3. age = age || 18;
      4. this.name = name;
      5. this.age = age;
      6. }
      7. People.prototype.eat = function() {
      8. console.log(this.name + '賊能吃');
      9. }
      10. function Cat(color, name, age) {
      11. this.color = color;
      12. People.call(this, name, age) //用call的形式把私有屬性繼承過來
      13. }
      14. function Fn() {} //創建一個中間構造函數,用來接收People的公有屬性,為了防止創建實例Cat實例是影響原來的people構造函數
      15. Fn.prototype = People.prototype;
      16. Cat.prototype = new Fn(); //將中間構造函數Fn繼承people的公有屬性傳給Cat的原型鏈
      17. Cat.prototype.constructor = Cat; //由于上一步重置了Cat原型鏈的constructor屬性,所以要重新給賦回來;
      18. var cat = new Cat('藍白色', '小叮當', 3);
      19. console.log(cat.name); //'小叮當'
      20. cat.eat() //'小叮當賊能吃


      注:若有不嚴謹與錯誤的地方,請多指教!






      1. 這里寫圖片描述



      藍藍設計www.li-bodun.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務


      日歷

      鏈接

      個人資料

      藍藍設計的小編 http://www.li-bodun.cn

      存檔

      主站蜘蛛池模板: 国产精品无码久久久一区蜜臀| 精品国产一区二区三区四区色| 六月丁香婷婷色狠狠久久| 九九久久精品国产波多野结衣| 2018av无码视频在线播放| 一级呦女专区毛片| 四虎国产精品永久一区| 欧美最爽乱婬视频免费看| 北川| 男女啪啪永久免费网站| av永久免费网站在线观看| 国产传媒麻豆剧精品av| 日韩欧美高清dvd碟片| 精品无码午夜福利理论片| 免费一级成人毛片| 国产手机在线小视频免费观看| 婷婷丁香五月六月综合激情啪| 蕉岭县| 欧美综合婷婷欧美综合五月| 国偷自产一区二区三区在线视频| 综合亚洲色图| 伊金霍洛旗| 男人狂桶女人出白浆免费视频| 亚洲国产日韩一区三区| 国产精品亚洲一区二区在线观看| 亚洲熟妇av一区二区三区宅男| 亚洲黄片手机免费观看| 女同亚洲精品一区二区三| 四虎成人精品无码| 中文字幕亚洲欧美日韩2019| 亚洲一区二区三区日本久久九| 美女禁区a级全片免费观看| 国产另类ts人妖一区二区| 久久综合色一综合色88| 久久大香萑太香蕉av黄软件| 免费观看一区二区| 国产成本人片免费a∨短片| 制服丝袜视频国产一区| 日韩av一区二区不卡在线| 亚洲国产精品成人综合色| 日韩国产亚洲一区二区三区|