<strike id="g3zqm"></strike>

      <cite id="g3zqm"></cite>

        <tr id="g3zqm"><center id="g3zqm"></center></tr>
        <pre id="g3zqm"><sup id="g3zqm"></sup></pre>
        <li id="g3zqm"></li>
      1. 少妇高潮激情一区二区三,免费av深夜在线观看,亚洲狼人久久伊人久久伊,久久精品人人做人人爽电影蜜月,黄色特级片一区二区三区,欧美日韩在线亚洲二区综二,极品少妇无套内射视频,日本极品少妇videossexhd

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

        2018-6-29    seo達人

        如果您想訂閱本博客內(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('小叮當', 200);//實例化一個People類,并賦值給Cat類的原型鏈
        14. var cat = new Cat('藍白色')
        15. console.log(cat.name)//'小叮當'
        16. cat.eat();//'小叮當賊能吃'

        二、混合模式繼承

            用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('藍白色', '小叮當', 1);
        16. console.log(cat.name);//'小叮當'
        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('藍白色', '小叮當', 200)
        17. console.log(cat)
        18. console.log(cat.name); //'小叮當',在原型鏈繼承的時候,就近原則,cat.name 先找到'小叮當',就不往下找了
        19. cat.eat(); //'小叮當賊能吃'

        三、拷貝繼承

            優(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('藍白色', '小叮當', 2);
        18. console.log(cat.name); //小叮當
        19. cat.eat(); //小叮當賊能吃

        四、寄生組合方式繼承

            優(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('藍白色', '小叮當', 3);
        19. console.log(cat.name); //'小叮當'
        20. cat.eat() //'小叮當賊能吃


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






        1. 這里寫圖片描述



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


        日歷

        鏈接

        個人資料

        藍藍設(shè)計的小編 http://m.hengshangtqd.cn

        存檔

        主站蜘蛛池模板: 国产精品久久久久7777| 久久精品国产亚洲AV无码不| 日日噜噜夜夜狠狠视频欧美人 | 欧美日韩一卡二卡| 亚洲国产成人无码AV在线| 欧美一区二区人人喊爽| 涩欲国产一区二区三区四区| 人妻少妇精品久久久久久0000| 色综合日韩| 亚洲一区二区三区激情视频| 福利社在线播放| 强奷乱码中文字幕| 久久亚洲精品成人av秋霞| 亚洲成A| 五月综合激情婷婷六月| 久久18禁高潮出水呻吟娇喘| 日本亚洲色大成网站WWW久久| 日韩人妻无码一区二区三区| 中文字幕无码专区一VA亚洲V专| 欧美丝袜你懂的| 日韩熟女精品一区二区三区| 91热国内精品永久免费观看 | 亚洲人成人网站色www| 91真实人妻宾馆露脸 | 欧美成人精品第一区二区三区| 久天啪天天久久99久孕妇| 免费观看国产女人高潮视频| 熟女中字在线| 日本夜爽爽一区二区三区| 国产精品v片在线观看不卡| 欧美人与zoxxxx另类| 国产国语一级毛片| 精品国产乱码一区二| 精品人妻一区二区三区四区在线| 新源县| 亚洲最猛黑人xxxx黑人猛交| 国产午夜福利小视频合集| 国产av第一次处破| 吉川爱美一区二区三区视频| 久久超碰97中文字幕亚洲| www.色吊丝av.com|