• <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <small id="ggggg"></small> <sup id="ggggg"></sup>
    <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <tfoot id="ggggg"></tfoot>
  • <nav id="ggggg"><cite id="ggggg"></cite></nav>
    <nav id="ggggg"></nav>
    成人黃色A片免费看三更小说,精品人妻av区波多野结衣,亚洲第一极品精品无码,欧美综合区自拍亚洲综合,久久99青青精品免费观看,中文字幕在线中字日韩 ,亚洲国产精品18久久久久久,黄色在线免费观看

    js學(xué)習(xí)中的總結(jié)——幾種繼承模式

    2018-6-29    seo達(dá)人

    如果您想訂閱本博客內(nèi)容,每天自動發(fā)到您的郵箱中, 請點這里

         js中構(gòu)造函數(shù)的幾種繼承模式淺析

    一、原型鏈模式繼承

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

        用的最多。

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

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

    二、混合模式繼承

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

    
            
    1. function People(name, age) { //創(chuàng)建一個父級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('藍(lán)白色', '小叮當(dāng)', 1);
    16. console.log(cat.name);//'小叮當(dāng)'
    17. cat.eat();//報錯,
    18. //繼承不了公有屬性,所以cat.eat()會報錯;

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

    
            
    1. function People(name, age) { //創(chuàng)建一個父級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('藍(lán)白色', '小叮當(dāng)', 200)
    17. console.log(cat)
    18. console.log(cat.name); //'小叮當(dāng)',在原型鏈繼承的時候,就近原則,cat.name 先找到'小叮當(dāng)',就不往下找了
    19. cat.eat(); //'小叮當(dāng)賊能吃'

    三、拷貝繼承

        優(yōu)點:可以多繼承,可傳參;

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

    
            
    1. function People(name, age) { //創(chuàng)建一個父級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('藍(lán)白色', '小叮當(dāng)', 2);
    18. console.log(cat.name); //小叮當(dāng)
    19. cat.eat(); //小叮當(dāng)賊能吃

    四、寄生組合方式繼承

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

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

    
            
    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() {} //創(chuàng)建一個中間構(gòu)造函數(shù),用來接收People的公有屬性,為了防止創(chuàng)建實例Cat實例是影響原來的people構(gòu)造函數(shù)
    15. Fn.prototype = People.prototype;
    16. Cat.prototype = new Fn(); //將中間構(gòu)造函數(shù)Fn繼承people的公有屬性傳給Cat的原型鏈
    17. Cat.prototype.constructor = Cat; //由于上一步重置了Cat原型鏈的constructor屬性,所以要重新給賦回來;
    18. var cat = new Cat('藍(lán)白色', '小叮當(dāng)', 3);
    19. console.log(cat.name); //'小叮當(dāng)'
    20. cat.eat() //'小叮當(dāng)賊能吃


    注:若有不嚴(yán)謹(jǐn)與錯誤的地方,請多指教!






    1. 這里寫圖片描述



    藍(lán)藍(lán)設(shè)計www.lzhte.cn )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 平面設(shè)計服務(wù)


    日歷

    鏈接

    個人資料

    存檔

    主站蜘蛛池模板: 免费无码AV一区二区波多野结衣| 亚洲日韩图片专区小说专区| 秋霞电影院午夜无码免费视频| 欧美不卡无线在线一二三区观| 无码日韩做暖暖大全免费不卡| 久久999精品国产只有精品| 成人免费A级毛片无码| 亚洲国产精品成人AV在线| 日日摸夜夜添夜夜添人人爽| 亚洲av日韩aⅴ永久无码| 国产99久久九九精品无码| 色偷偷亚洲精品一区二区| 激情五月开心婷婷深爱| 亚洲阿v天堂网2021| 中文字幕在线永久免费视频| 无码喷水一区二区浪潮AV| 城市| 荥经县| 在线免费观看污视频| 3D动漫精品一区二区三区| 日欧一片内射va在线影院| 欧美日韩国产在线人成app| 丁香五月亚洲综合深深爱| 毛茸茸性xxxx毛茸茸毛茸茸| 欧美亚洲国产精品久久| 成年av福利永久免费观看| 亚洲一区二区三区电影在线观看| 污污网站在线看| 另类综合网| 麻豆文化传媒精品一区二区| 黑人与人妻无码中字视频| 亚洲自偷精品视频自拍| 亚洲AV无码成人精品区日韩密殿| 久久综合噜噜激激的五月天| 日韩AV在线网址观看| 欧美极品色午夜在线视频| 成人区男人天堂av网| 久久国产精品亚洲综合| 国产人成午夜免免费观看| 亚洲一区二区三区激情视频 | 久爱午夜精品免费视频|