JavaScript模擬實(shí)現(xiàn)封裝的三種方式及寫法區(qū)別
前 言
繼承是使用一個(gè)子類繼承另一個(gè)父類,那么子類可以自動(dòng)擁有父類中的所有屬性和方法,這個(gè)過程叫做繼承! JS中有很多實(shí)現(xiàn)繼承的方法,今天我給大家介紹其中的三種吧。
1.在 Object類上增加一個(gè)擴(kuò)展方法
//聲明一個(gè)父類 function Person(name){ this.name=name; this.age=age; this.say=function(){ alert("我叫"+this.name); } } //聲明一個(gè)子類 function Student(){ this.no=no; this.study=function(){ alert("我在學(xué)習(xí)!"); } } // 通過循壞,將父類對象的所有屬性和方法,全部賦給子類對象 Object.prototype.extend=function(parent){ for(var i in parent){ this[i].parent[i]; } } var p=new Person("張三",12); var s=new Student("1234567"); //子類對象調(diào)用這個(gè)擴(kuò)展方法 s.extend() console.log(s);
上述實(shí)現(xiàn)繼承的原理:
通過循壞,將父類對象的所有屬性和方法,全部賦給子類對象。關(guān)鍵點(diǎn)在于for-in循壞,即使不擴(kuò)展Object,也能通過簡單的循壞實(shí)現(xiàn)操作。
但是用這種方法實(shí)現(xiàn)繼承也有一些缺點(diǎn):
①無法通過一次實(shí)例化,直接拿到完整的子類對象。而需要先拿到父類對象和子類對象兩個(gè)對象,再手動(dòng)合并;
②擴(kuò)展Object的繼承方法,也會(huì)保留在子類的對象上。
再來看看第二種實(shí)現(xiàn)繼承的方法吧~
2.使用原型繼承
在介紹這種方法之前先來說兩個(gè)概念:原型對象與原型
1、prototype:函數(shù)的原型對象
①只有函數(shù)才有prototype,而且所有函數(shù)必有prototype
②prototype本身也是一個(gè)對象!
③prototype指向了當(dāng)前函數(shù)所在的引用地址!
2、__proto__:對象的原型!
①只有對象才有__proto__,而且所有對象必有__proto__
②__proto__也是一個(gè)對象,所以也有自己的__proto__,順著這條線向上照的順序,就是原型鏈。
③函數(shù)、數(shù)組都是對象,都有自己的__proto__
//聲明父類 function Person(name,age){ this.name=name; this.age=age; this.say=function(){ alert("我叫"+this.name); } } //聲明子類 function Student(no){ this.no=no; this.study=function(){ alert("我在學(xué)習(xí)!我叫"+this.name+"今年"+this.age"); } } //將父類對象賦給子類的prototype Student.prototype=new Person("張三",14); //拿到子類對象時(shí),就會(huì)將父類對象的所有屬性和方法,添加到__proto__ var s=new Student(); s.study();
使用原型繼承的原理:
將父類對象,賦值給子類的prototype,那么父類對象的屬性和方法就會(huì)出現(xiàn)在子類的prototype中。那么,實(shí)例化子類時(shí),子類的prototype又會(huì)到子類對象的__proto__中,最終,父類對象的屬性和方法,會(huì)出現(xiàn)在子類對象的__proto__中。
這種繼承的特點(diǎn):
①子類自身的所有屬性都是成員屬性,父類繼承過來的屬性都是原型屬性。
②依然無法通過一步實(shí)例化拿到完成的子類對象。
第三種實(shí)現(xiàn)繼承的方法:
call()和apply()還有bind(),這三種方法很相似,只有在傳參方面有所不同。
function Person(name,age){ this.name=name; this.age=age; this.say=function(){ alert("我叫"+this.name); } } function Student(no,name,age){ this.no=no; this.study=function(){ alert("我在學(xué)習(xí)!"); } //將父類函數(shù)的this,指向?yàn)樽宇惡瘮?shù)的this Person.call(this,name,age); } var s=new Student(12,"張三",24); console.log(s);
三個(gè)函數(shù)的唯一區(qū)別,在于接受func的參數(shù)列表的方式不同,除此之外,功能上沒有任何差異!
三個(gè)函數(shù)的寫法(區(qū)別):
call寫法:func.call(func的this指向的obj,func參數(shù)1,func參數(shù)2,...);
apply寫法:func.apply(func的this指向的obj,[func參數(shù)1,func參數(shù)2,...]);
bind寫法:func.bind(func的this指向的obj)(func參數(shù)1,func參數(shù)2,...);
總結(jié)
以上所述是小編給大家介紹的JavaScript模擬實(shí)現(xiàn)封裝的三種方式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
uni-app如何用JS動(dòng)態(tài)修改scss樣式變量
對于uni-app中的組件,可以通過修改它們的樣式來自定義它們的外觀,下面這篇文章主要給大家介紹了關(guān)于uni-app如何用JS動(dòng)態(tài)修改scss樣式變量的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07JavaScript實(shí)現(xiàn)頁面高亮操作提示和蒙板
這篇文章主要介紹了JavaScript實(shí)現(xiàn)頁面高亮操作提示和蒙板,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01JavaScript操作XML/HTML比較常用的對象屬性集錦
本文給大家介紹javascript操作xml/html比較常用的對象屬性,涉及到j(luò)s對象屬性相關(guān)知識,對JavaScript操作XML/HTML比較常用的對象屬性感興趣的朋友可以參考下本文2015-10-10webpack5處理圖片、圖標(biāo)字體、多媒體等靜態(tài)資源文件
在 webpack5 中內(nèi)置了 file-loader、url-loader、raw-loader, 可以直接通過配置實(shí)現(xiàn)常用功能,下面就來介紹一下webpack5處理圖片、圖標(biāo)字體、多媒體等靜態(tài)資源文件的實(shí)現(xiàn)方法,感興趣的可以了解一下2023-12-12javascript寫一個(gè)ajax自動(dòng)攔截并下載數(shù)據(jù)代碼實(shí)例
這篇文章主要介紹了javascript寫一個(gè)ajax自動(dòng)攔截并下載數(shù)據(jù)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09