97国产精品视频人人做人人爱,3344在线观看无码,成年人国产视频,欧美日一级片,在线看AV天堂,高清无码一本到东京热,欧美一级黄片一区2区,免费又爽又刺激高潮网址

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.0391cbd.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務


日歷

鏈接

個人資料

藍藍設計的小編 http://www.0391cbd.com

存檔

主站蜘蛛池模板: 亚洲三级电影在线播放| 国产成人高清精品免费5388| 丝袜无码一区二区三区| 97在线碰| 99热精品久久| 亚洲国产亚洲综合在线尤物| 美女一级免费毛片| 国产成人喷潮在线观看| 片在线无码观看| 中文天堂在线视频| 91口爆吞精国产对白第三集| 久久综合伊人77777| 国产99热| 鲁鲁鲁爽爽爽在线视频观看 | 动漫精品中文字幕无码| 视频二区中文无码| 国产成人亚洲综合a∨婷婷| 激情六月丁香婷婷| 亚洲系列无码专区偷窥无码| 成年人福利视频| 国产一区二区三区在线观看视频| 国产精品亚欧美一区二区三区 | 久夜色精品国产噜噜| 国产欧美日韩综合在线第一| 亚洲精品大秀视频| 黄色片中文字幕| 最新加勒比隔壁人妻| 一区二区影院| 欧美日韩第二页| 最新国语自产精品视频在| 91亚洲免费视频| 六月婷婷激情综合| 五月天丁香婷婷综合久久| 国产九九精品视频| 亚洲另类色| 亚洲欧美日韩视频一区| 伊人色在线视频| www.国产福利| 午夜电影在线观看国产1区| 91色国产在线| 国产呦视频免费视频在线观看| 青青草综合网| 国产精品大白天新婚身材| 99久久精品国产麻豆婷婷| 欧美精品亚洲精品日韩专区| 91青青视频| 亚洲国产综合第一精品小说| 亚洲日韩精品无码专区| 九九这里只有精品视频| 草草影院国产第一页| 香蕉国产精品视频| 欧美啪啪精品| 精品少妇人妻一区二区| 国产成人毛片| 免费毛片在线| 欧美中出一区二区| 精品无码一区二区三区电影| 综合色婷婷| 国产乱人乱偷精品视频a人人澡| 一区二区三区高清视频国产女人| 亚洲精品男人天堂| 精品久久久久久中文字幕女| 干中文字幕| 熟女成人国产精品视频| 99久久国产综合精品女同| Aⅴ无码专区在线观看| 波多野结衣无码视频在线观看| 精品一区二区三区水蜜桃| 成年片色大黄全免费网站久久| 国产午夜一级淫片| 日本成人一区| 国产成人亚洲综合A∨在线播放 | 日韩精品无码免费一区二区三区| 久久久91人妻无码精品蜜桃HD| 人与鲁专区| 人妻一区二区三区无码精品一区| 丁香五月亚洲综合在线| 被公侵犯人妻少妇一区二区三区| 中文字幕永久在线看| 久草热视频在线| 欧美激情视频一区二区三区免费| 欧美在线视频不卡第一页|