92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线

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


日歷

鏈接

個人資料

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

存檔

92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线
国产免费一区二区三区香蕉精| 在线播放国产一区中文字幕剧情欧美| 一本色道久久88综合亚洲精品ⅰ| 91国产美女视频| 韩日欧美一区二区| 成人中心免费视频| 九九热r在线视频精品| 国产欧美欧洲在线观看| 91手机视频在线观看| 欧美国产精品va在线观看| 欧美制服第一页| 在线亚洲男人天堂| 成人免费在线网址| 中文字幕亚洲欧美日韩在线不卡| 成人国内精品久久久久一区| 亚洲欧美制服另类日韩| 国模精品一区二区三区色天香| 亚洲综合中文字幕68页| 亚洲天堂成人在线视频| 欧美日韩国产激情| 国产日本欧美一区二区三区| 91日韩在线播放| 久久久久久国产免费| 亚洲国产精品一区二区久| 亚洲a∨日韩av高清在线观看| 国产精品美女在线观看| 中日韩午夜理伦电影免费| 欧美片一区二区三区| 欧美日韩亚洲一区二区| 韩国v欧美v日本v亚洲| 日韩欧美在线视频日韩欧美在线视频| 精品国产一区二区三区四区在线观看| 亚洲嫩模很污视频| 欧美老少做受xxxx高潮| 亚洲第一区在线| 欧美激情久久久久| 欧美激情综合色综合啪啪五月| 欧美电影在线播放| 日韩精品视频免费专区在线播放| 国产精品爱久久久久久久| 欧美大片欧美激情性色a∨久久| 在线国产精品播放| 国产精品视频男人的天堂| 中文字幕v亚洲ⅴv天堂| 91色中文字幕| 欧美一级淫片播放口| 国产视频自拍一区| 欧美大片在线看| 日韩精品亚洲视频| 亚洲加勒比久久88色综合| 欧美乱大交做爰xxxⅹ性3| 久久视频在线免费观看| 欧美在线观看www| 日韩视频在线观看免费| 久久亚洲国产精品| 亚洲日韩中文字幕| 国产欧美最新羞羞视频在线观看| 欧美壮男野外gaytube| 亚洲日韩欧美视频| 亚洲欧美国产视频| 欧美成人四级hd版| 91精品久久久久久久久久久久久久| 精品久久久久久久久久久久久| 亚洲国产精久久久久久| 国产在线拍偷自揄拍精品| 久久久久成人网| 精品久久久久久中文字幕大豆网| 国产在线拍揄自揄视频不卡99| 欧美黄色三级网站| 日韩av手机在线看| 国产在线日韩在线| 国产一区二区在线免费| 中文字幕亚洲无线码a| 最近2019中文字幕在线高清| 国产精品白丝jk喷水视频一区| 精品成人在线视频| 国产欧美一区二区三区视频| 欧美另类精品xxxx孕妇| 久久精品男人天堂| 亚洲www在线观看| 久久久久久久久久国产精品| 国产精品流白浆视频| 国产成人综合av| 国产亚洲美女久久| 久久精品电影网站| 国产v综合v亚洲欧美久久| 日韩免费在线电影| 两个人的视频www国产精品| 日韩欧美高清视频| 激情亚洲一区二区三区四区| 国产日韩欧美91| 国产精品久久久久久久app| 另类天堂视频在线观看| 亚洲人成网站在线播| 久久人人爽国产| 亚洲色图偷窥自拍| 77777少妇光屁股久久一区| 97久久精品人搡人人玩| 亚洲国产另类久久精品| 成人亚洲欧美一区二区三区| 亚洲国产欧美一区二区丝袜黑人| 国产在线视频欧美| 欧美日韩一区二区三区| 亚洲久久久久久久久久| 日韩av电影在线免费播放| 岛国视频午夜一区免费在线观看| 2018中文字幕一区二区三区| 欧美激情一区二区三区久久久| 精品欧美aⅴ在线网站| 欧美在线播放视频| 欧美视频第一页| 亚洲精品成人网| 一区二区在线免费视频| 日韩久久免费电影| 国产精品爱久久久久久久| 大桥未久av一区二区三区| 日本精品免费一区二区三区| 一区二区三区www| 国产亚洲一区精品| 国产成人在线一区| 亚洲国产高清福利视频| 国产丝袜一区二区三区免费视频| 国产在线观看精品| 亚州国产精品久久久| 国产精品久久激情| 日韩成人在线播放| 欧美成人精品在线| 国内精品小视频| 国产成人免费91av在线| 91在线免费观看网站| www.精品av.com| 91国产视频在线| 欧美性视频在线| 国产精品久久久久久久美男| 欧美成人小视频| 97视频免费在线看| 精品久久久久久久久久久久| 色999日韩欧美国产| 亚洲日本aⅴ片在线观看香蕉| 97在线观看免费高清| 亚洲片在线资源| 亚洲精品国精品久久99热一| 精品一区二区三区四区在线| 91亚洲精品一区| 亚洲无亚洲人成网站77777| 久热99视频在线观看| 亚洲欧美日韩一区在线| 色播久久人人爽人人爽人人片视av| 亚洲欧美日本精品| 国产小视频91| 欧美一级在线亚洲天堂| 国产成人精品网站| 精品国产91久久久| 欧美一区二区三区四区在线| 久热精品视频在线观看一区| 久热99视频在线观看| 91精品国产成人www| 欧美日韩激情美女| 欧美日韩午夜激情| 136fldh精品导航福利| 日韩免费看的电影电视剧大全| 色www亚洲国产张柏芝| 国产精品久久久久久久av大片| 最近的2019中文字幕免费一页|