日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

js 中的五种继承方法

發布時間:2025/5/22 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js 中的五种继承方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

正式發布的ES6中已經封裝實現了其他OO語言中的繼承形式,Class Extends,這里主要記錄js的原型繼承和借用構造函數繼承

一、原型鏈繼承

function Super(){this.name="小明"; } Super.prototype.sayName = function(){alert(this.name) }; function Sub(){}Sub.prototype = new Super(); var instance = new Sub(); instance.sayName();//小明

原型鏈繼承的問題

//當超類中包含引用類型屬性值時,其中一個子類的多個實例中,只要其中一個實例引用屬性只發生修改一個修改,其他實例的引用類型屬性值也會立即發生改變 //原因是超類的屬性變成子類的原型屬性 function Super(){ this.name="小明";this.friends = ['小紅','小強']; } Super.prototype.sayName = function(){alert(this.name) }; function Sub(){}Sub.prototype = new Super(); var instance1 = new Sub(); var instance2 = new Sub(); instance1.friends.push('張三'); console.log(instance1.friends);//["小紅", "小強", "張三"] console.log(instance2.friends);//["小紅", "小強", "張三"]

二、借用構造函數繼承

function Super(){ this.name="小明";this.friends = ['小紅','小強']; } Super.prototype.sayName = function(){alert(this.name) }; function Sub(){Super.call(this); }var instance1 = new Sub(); var instance2 = new Sub(); instance1.friends.push('張三'); console.log(instance1.friends);//["小紅", "小強", "張三"] console.log(instance2.friends);//["小紅", "小強"]

借用構造函數的問題

單獨使用借用構造函數,沒辦法繼承超類中的原型屬性和方法

三、組合式繼承(原型繼承+借用構造函數繼承)

組合式繼承也是實際開發中最常用的繼承方式

function Super(){ this.name="小明";this.friends = ['小紅','小強']; } Super.prototype.sayName = function(){alert(this.name) }; function Sub(){Super.call(this); }Sub.prototype = new Super(); var instance1 = new Sub(); var instance2 = new Sub(); instance1.friends.push('張三'); console.log(instance1.friends);//["小紅", "小強", "張三"] console.log(instance2.friends);//["小紅", "小強"] instance1.sayName();//小明 instance2.sayName();//小明

組合式繼承的問題

//組合式繼承中,超類的構造函數將被調用兩次 function Super(){ this.name="小明";this.friends = ['小紅','小強']; } Super.prototype.sayName = function(){alert(this.name) }; function Sub(){Super.call(this);//第二次調用 }Sub.prototype = new Super();//第一次調用 var instance = new Sub();

四、寄生式繼承

//在主要考慮對象而不是自己定義類型和構造函數的情況下,寄生式繼承是一種有用的模式,但無法做到函數的復用 function createAnother(original){var clone = Object(original);//創建一個新對象,original的副本clone.sayName = function(){ //對象的增強,添加額外的方法alert('hi');}return clone; } var person = {name:'小明',friends:['小紅','小強'] } var person1 = createAnother(person); var person2 = createAnother(person); person1.friends.push('張三'); console.log(person.friends);//["小紅", "小強", "張三"] console.log(person1.friends);//["小紅", "小強", "張三"] console.log(person2.friends);//["小紅", "小強", "張三"]

寄生組合式繼承

//寄生組合式繼承解決了組合式繼承調用兩次超類構造函數的問題 function inheritPrototype(sub,superr){ var prototype = Object.create(superr.prototype);//ES5中創建對象副本的方法prototype.constructor = superr; //彌補重寫原型失去的默認constructor屬性sub.prototype = prototype; } function Super(name){this.name = name;this.friends = ['小紅','小強']; } Super.prototype.sayName = function(){alert(this.name); } function Sub(name){Super.call(this,name); } inheritPrototype(Sub,Super); var person1 = new Sub('小明'); var person2 = new Sub('小華'); person1.friends.push('張三'); console.log(person1.friends);//["小紅", "小強", "張三"] console.log(person2.friends);//["小紅", "小強"] console.log(person1.sayName());//小明 console.log(person2.sayName());//小華

轉載于:https://www.cnblogs.com/tuboshu/p/10752356.html

總結

以上是生活随笔為你收集整理的js 中的五种继承方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 天天插天天干天天操 | 成人精品一区二区三区视频 | 强辱丰满人妻hd中文字幕 | 久久久久久久久久一级 | 黄色网页免费在线观看 | 一区二区三区视频网站 | 久久久久久国 | 国产精品久久久久久久无码 | 日韩欧av| 日韩黄色网址 | 手机在线中文字幕 | 无码人妻aⅴ一区二区三区有奶水 | 精品午夜福利在线观看 | 国产精品视频一区二区三区, | 亚洲欧美一二三区 | 久久久久99精品成人片我成大片 | 亚洲av成人精品午夜一区二区 | 黄色操人视频 | 国产精品国产三级国产aⅴ无密码 | 亚洲三级图片 | 日韩精品一区二区三区国语自制 | 国产国语对白 | 青青草视频黄 | 特级精品毛片免费观看 | 99精品在线| 狠狠插av | 日韩欧美不卡在线 | 日韩不卡中文字幕 | 亚洲国产午夜 | 婷婷综合 | 国产91在线观看丝袜 | 国产精品高潮视频 | 久久久久久逼 | 国产精品亚洲无码 | 日韩免费视频一区二区 | 亚洲欧美不卡 | 久久青草热| 操女人的逼逼 | 中文字幕亚洲激情 | 天天久| 成人动漫在线播放 | 99热这里只 | 免费观看在线高清 | 99热这里只有精品久久 | 成人av播放 | 99视频热 | 亚洲五月六月 | 午夜黄色 | 少妇4p| a v视频在线播放 | 亚洲综合热 | 草莓视频18免费观看 | 色妞综合| 91麻豆产精品久久久久久 | 国产真人无码作爱视频免费 | 亚洲7777 | 久久成人高清 | 99久久免费国产精精品 | 大桥未久恸哭の女教师 | 日韩伦理中文字幕 | 伊人成人在线观看 | 国产夫绿帽单男3p精品视频 | 日日碰狠狠添天天爽 | 日韩av电影网址 | 久久靖品 | 国产自产一区二区 | 熟妇人妻无乱码中文字幕真矢织江 | 国产情侣在线视频 | 精品在线观看一区 | 古代黄色一级片 | 亚洲欧美日韩国产 | 麻豆tube| av操操操| 免费av网站在线观看 | 成人一卡二卡 | 国产精品区二区三区日本 | 久久综合五月婷婷 | 欧洲美女与动交zozzo | 中国亚洲老头同性gay男男… | 手机成人在线视频 | 久久国产乱子 | 99cao| 亚洲激情久久久 | 日本熟妇色xxxxx日本免费看 | 性一交一乱一色一免费无遮挡 | 亚洲精品欧洲精品 | 天天操天天操天天射 | 中文字幕在线视频网 | 久草黄色 | 国产精品欧美一区喷水 | 手机看片欧美 | 琪琪成人 | 亚洲宅男天堂 | 亚洲精品无码一区二区 | 国产一区二区在线免费观看 | 一区二区欧美精品 | 欧美变态口味重另类 | 91jk制服白丝超短裙大长腿 | 永久免费av无码网站性色av |