亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

Javascript編程中幾種繼承方式比較分析

2024-05-06 16:25:23
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Javascript編程中幾種繼承方式比較分析,較為詳細的分析了JavaScript繼承的原理并對比分析了幾種繼承方式的實現技巧,需要的朋友可以參考下
 

本文實例分析了Javascript編程中幾種繼承方式比較。分享給大家供大家參考,具體如下:

開篇

從'嚴格'意義上說,javascript并不是一門真正的面向對象語言。這種說法原因一般都是覺得javascript作為一門弱類型語言與類似java或c#之類的強型語言的繼承方式有很大的區別,因而默認它就是非主流的面向對象方式,甚至竟有很多書將其描述為'非完全面向對象'語言。其實個人覺得,什么方式并不重要,重要的是是否具有面向對象的思想,說javascript不是面向對象語言的,往往都可能沒有深入研究過javascript的繼承方式,故特撰此文以供交流。

為何需要利用javascript實現繼承

早期pc機器的性能確實不敢恭維,所有的壓力全在服務器端,客戶端瀏覽器純屬擺設。再加上那時流行的table布局以及電話線的上網方式導致瀏覽一個網頁十分的卡;而今互聯網時代飛速發展,個人電腦硬件得到了極大提升,客戶端瀏覽器的性能也十分的酸爽,web開發的模式也在悄悄改變:服務端不再像以前那樣“辛苦”,取而代之的是盡可能的讓瀏覽器承擔更多的任務,如此一來,壓力分攤到每個客戶端上,企業不但節省成本,隨之也讓web前端開發變的更加有趣--越來越多的前端框架層出不窮,甚至出現了許多前端的MVC框架。在這種背景下,javascript的角色已經絕對不是只做一些簡單的驗證,發送一些請求或者操作一些DOM,更多的需要擔任類似前端路由和業務層的角色,并且javascript需要做大量的邏輯性任務,這里面就包括前臺數據的抽離(即model),而只有運用面向對象的思維才能很好的對抽離數據進行處理,因此繼承就在這里顯得舉足輕重。

從一個簡單的需求開始

現從前臺抽離一個model名為Person,其有基本屬性name和age,默認每個人都會說話,因此將說話的功能say放在了原型對象上,以供每個實例享用。現在對于Man來說,它需要繼承Person的基本屬性,并且在此基礎上添加自己特有的屬性。

function Person (name, age) {  this.name = name;  this.age = age;}Person.prototype.say = function(){  console.log('hello, my name is ' + this.name);};function Man() {  //my own properties}

下面介紹幾種主流的繼承方式。

1.原型鏈繼承

function Person (name, age) {  this.name = name;  this.age = age;}Person.prototype.say = function(){  console.log('hello, my name is ' + this.name);};function Man() {}Man.prototype = new Person('pursue');var man1 = new Man();man1.say(); //hello, my name is pursuevar man2 = new Man();console.log(man1.say === man2.say);//trueconsole.log(man1.name === man2.name);//true

這種繼承方式很直接,為了獲取Person的所有屬性方法(實例上的和原型上的),直接將父類的實例new Person('pursue')賦給了子類的原型,其實子類的實例man1,man2本身是一個完全空的對象,所有的屬性和方法都得去原型鏈上去找,因而找到的屬性方法都是同一個。 
所以直接利用原型鏈繼承是不現實的。

2.利用構造函數繼承

function Person (name, age) {  this.name = name;  this.age = age;}Person.prototype.say = function(){  console.log('hello, my name is ' + this.name);};function Man(name, age) {  Person.apply(this, arguments);}//Man.prototype = new Person('pursue');var man1 = new Man('joe');var man2 = new Man('david');console.log(man1.name === man2.name);//falseman1.say(); //say is not a function

這里子類的在構造函數里利用了apply去調用父類的構造函數,從而達到繼承父類屬性的效果,比直接利用原型鏈要好的多,至少每個實例都有自己那一份資源,但是這種辦法只能繼承父類的實例屬性,因而找不到say方法,為了繼承父類所有的屬性和方法,則就要修改原型鏈,從而引入了組合繼承方式。

3.組合繼承

function Person (name, age) {  this.name = name;  this.age = age;}Person.prototype.say = function(){  console.log('hello, my name is ' + this.name);};function Man(name, age) {  Person.apply(this, arguments);}Man.prototype = new Person();var man1 = new Man('joe');var man2 = new Man('david');console.log(man1.name === man2.name);//falseconsole.log(man1.say === man2.say);//trueman1.say(); //hello, my name is joe

需要注意的是man1和man2的實例屬性其實是覆蓋了原型屬性,但是并沒要覆蓋掉原型上的say方法(因為它們沒有),所以這里man1.say === man2.say依然返回true,因而需要十分小心沒有覆蓋掉的原型屬性,因為它是所有實例共有的。

4.寄生組合繼承

說實話我真不知道下面的這種形式叫這名字,但是它確實是最流行,最經典的javascript的繼承方式。其實,只需要明白原型對象的結構即可:

function Person (name, age) {  this.name = name;  this.age = age;}Person.prototype.say = function(){  console.log('hello, my name is ' + this.name);};function Man(name, age) {  Person.apply(this, arguments);}Man.prototype = Object.create(Person.prototype);//a.Man.prototype.constructor = Man;//b.var man1 = new Man('pursue');var man2 = new Man('joe');console.log(man1.say == man2.say);console.log(man1.name == man2.name);

其實寄生組合繼承和上面的組合繼承區別僅在于構造子類原型對象的方式上(a.和b.),這里用到了Object.creat(obj)方法,該方法會對傳入的obj對象進行淺拷貝,類似于:

function create(obj){  function T(){};  T.prototype = obj;  return new T();}

因此,a.會將子類的原型對象與父類的原型對象進行很好的連接,而并不像一般的組合繼承那樣直接對子類的原型進行復制(如Man.prototype = new Person();),這樣只是很暴力的在對屬性進行覆蓋。而寄生組合繼承方式則對實例屬性和原型屬性分別進行了繼承,在實現上更加合理。

注意:代碼b.并不會改變instanceof的結果,但是對于需要用到construcor的場景,這么做更加嚴謹。

希望本文所述對大家JavaScript程序設計有所幫助。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲自拍偷拍网址| 亚洲第一二三四五区| 亚洲第一免费播放区| 国产视频久久久久久久| 久久高清视频免费| 国产精品99导航| 亚洲欧美日韩网| 日韩免费观看视频| 欧美激情视频在线免费观看 欧美视频免费一| 欧美成人精品在线| 欧美成在线观看| 欧美日韩在线观看视频小说| 亚洲激情在线观看| 久久久精品亚洲| 亚洲色图第一页| **欧美日韩vr在线| 2019中文字幕在线观看| 久久资源免费视频| 中文字幕免费国产精品| 青青青国产精品一区二区| 久久精品电影网| 国产日韩综合一区二区性色av| 欧美成年人网站| 97在线免费观看视频| 成人福利视频网| 97高清免费视频| 51久久精品夜色国产麻豆| 日韩高清av在线| 欧美国产日韩免费| 久久久99久久精品女同性| 国产一区二区三区在线播放免费观看| 欧美日韩国产精品一区| 欧美日韩免费网站| 中文字幕欧美亚洲| 国产精品福利在线观看| 亚洲第一级黄色片| 日韩欧美在线视频免费观看| 国产人妖伪娘一区91| 精品国产一区二区三区久久狼5月| 68精品国产免费久久久久久婷婷| 欧美天堂在线观看| 亚洲欧洲免费视频| 午夜精品蜜臀一区二区三区免费| 欧美午夜美女看片| 精品国产一区二区在线| 黑人巨大精品欧美一区二区一视频| 亚洲一区二区在线| 久久男人的天堂| 4k岛国日韩精品**专区| 最近的2019中文字幕免费一页| 久久久www成人免费精品| 国产精品美女呻吟| 亚洲影院污污.| 久久亚洲精品网站| 久久天天躁狠狠躁夜夜躁2014| 欧美性色视频在线| 精品视频在线播放色网色视频| 久久91超碰青草是什么| 欧美大片免费观看| 精品成人国产在线观看男人呻吟| 国产91色在线免费| 国产美女精彩久久| 色综合久久88色综合天天看泰| 奇门遁甲1982国语版免费观看高清| 一夜七次郎国产精品亚洲| 欧美激情亚洲国产| 成人美女免费网站视频| 亚洲一区av在线播放| 亚洲a在线播放| 中文字幕日韩欧美精品在线观看| 欧美最猛性xxxx| 欧美午夜激情视频| 日本精品久久久| 国产午夜精品久久久| 欧美在线影院在线视频| 91地址最新发布| 欧美日产国产成人免费图片| 国产精品91在线观看| 色与欲影视天天看综合网| 国产97在线|亚洲| 日韩经典一区二区三区| 国产精品高潮呻吟久久av黑人| 日韩大胆人体377p| 久久久久久国产| 日本免费在线精品| 97视频在线播放| 在线成人激情黄色| 成人激情视频在线播放| 久久久久久久久久久久久久久久久久av| 欧美激情精品久久久久久黑人| 韩国国内大量揄拍精品视频| 在线成人激情视频| 国产不卡在线观看| 亚洲日本aⅴ片在线观看香蕉| 欧美日韩亚洲系列| 欧美做受高潮电影o| 国产精品欧美一区二区三区奶水| 亚洲xxxx3d| 97精品国产97久久久久久免费| 亚洲精品视频在线观看视频| 日韩欧美有码在线| 国产精品专区第二| 自拍偷拍亚洲一区| 成人黄色免费看| 国产精品爱啪在线线免费观看| 欧美自拍视频在线观看| 在线播放日韩欧美| 日韩中文字幕久久| 国产在线高清精品| 日韩av网站大全| 久久夜色精品国产| 日韩有码在线电影| 亚洲天堂成人在线| 国产精品久久综合av爱欲tv| 麻豆乱码国产一区二区三区| 91国内揄拍国内精品对白| 亚洲第一男人天堂| 国产精品99久久久久久久久久久久| 亚洲欧美一区二区三区四区| 欧美一区二区三区图| 欧美性猛交xxxx乱大交3| 久久精品精品电影网| 成人免费视频xnxx.com| 国产精品爱啪在线线免费观看| 国产一区香蕉久久| 热99久久精品| 国产精品日韩一区| 成人午夜激情免费视频| 亚洲黄色成人网| 一区二区在线视频| 欧美极度另类性三渗透| 国产精品久久久久91| 97超级碰在线看视频免费在线看| 亚洲天堂2020| 中文字幕亚洲第一| 欧美中文在线字幕| 俺也去精品视频在线观看| 久久久电影免费观看完整版| 美女999久久久精品视频| 综合久久五月天| 第一福利永久视频精品| 亚洲欧美日韩直播| 欧美激情精品久久久久久黑人| 久久频这里精品99香蕉| 欧美巨乳在线观看| 黑人与娇小精品av专区| 欧美大片大片在线播放| 国产一区二区精品丝袜| 亚洲精品永久免费| 亚洲国产精彩中文乱码av在线播放| 国产精品99蜜臀久久不卡二区| 欧美三级欧美成人高清www| 欧美大片免费看| 久久久伊人日本| 久久久免费av| 欧美午夜视频在线观看| 91系列在线播放| 欧美一级黑人aaaaaaa做受| 亚洲精品91美女久久久久久久| 国产亚洲精品91在线| 亚洲精品视频免费在线观看| 亚洲区在线播放| 久久精品久久久久久国产 免费| 久久精品久久久久久|