欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript繼承模式粗探

 更新時間:2016年01月12日 14:16:50   作者:卡卡頌  
之前提到了JS中比較簡單的設計模式,在各種設計模式中被最常使用的工具之一就是原型鏈的繼承。作為OOP的特質之一——繼承,今天主要談談JS中比較簡單的繼承方法

真正意義上來說Javascript并不是一門面向對象的語言,沒有提供傳統(tǒng)的繼承方式,但是它提供了一種原型繼承的方式,利用自身提供的原型屬性來實現(xiàn)繼承。Javascript原型繼承是一個被說爛掉了的話題,但是自己對于這個問題一直沒有徹底理解,今天花了點時間又看了一遍《Javascript模式》中關于原型實現(xiàn)繼承的幾種方法,下面來談談JS中比較簡單的繼承方法,如果大家有不同意見,歡迎建議。

最基礎的原型鏈繼承在這里就不復述了,主要講一下其他的繼承模式。

1.借用構造函數(shù)繼承

function Father (name) {
this.name=name;
}
function Son (name) {
Father.call(this,name); //在子類型中調用超類型的構造函數(shù)
this.age=15;
}
var me=new Son("Su"); 

好處:可以為子類型傳遞參數(shù),如圖中的name屬性。

壞處:1.方法在構造函數(shù)中定義,無法復用。2.超類型原型中定義的方法對子類型是不可見的。

2.組合繼承(綜合原型鏈與構造函數(shù))

//超類型構造函數(shù)function Father (name) {
this.name=name;
this.famMember=[];
}//超類型構造函數(shù)原型方法
Father.prototype.sayName=function () {
alert(this.name);
}//子類型構造函數(shù)
function Son (name,age) {
Father.call(this,name); //構造函數(shù)方法
this.age=age;
}
Son.prototype=new Father(); //重寫子類型原型對象
Son.prototype.constructor=Son; //重寫構造函數(shù)屬性指向子類型
Son.prototype.sayAge=function () {
alert(this.age);
} //重寫原型對象后再加入方法
var me=new Son("Su",15);
me.famMember.push("dad","mom"); //子類型可以調用超類型構造函數(shù)內的方法var he=new Son("Li",14);alert(he.famMember); // [] 

好處:不同的子類既可以擁有自己的屬性,也可以使用相同的方法。

壞處:這種方法需要調用2次超類型的構造函數(shù),同名的屬性方法會被覆蓋一次。

3.原型式繼承 (類似Object.create())

function object (o) {
function F () {}
F.prototype=o;
return new F();
}var obj={}; //將obj對象傳入作為新對象的原型。var me=object(obj); 

使用這種方法繼承需要有一個對象作為原型對象,所以所有繼承其的子類型的屬性方法都是共用的。

ES5通過新增Object.creatr()方法規(guī)范了原型式繼承。

4.寄生式繼承 (可以設置私有方法的原型式繼承)

function object (o) {
function F () {}
F.prototype=o;
return new F();
}
var obj={}; //將obj對象傳入作為新對象的原型。到這里都與原型式繼承相同function creObj(o) {  var clone=object(obj);  clone.sayHi=function () {    alert("Hi");  };return clone; }
var me=creObj(obj); 

好處:這種方式彌補了原型式繼承只有公有屬性方法的缺陷,使子類型能有私有屬性方法。

5.寄生組合式繼承

function inherit (father,son) {
var pro=Object(father.prototype); //創(chuàng)建超類型原型對象的副本
pro.constructor=son;
son.prototype=pro;           //將副本作為子類型的原型對象
} 

本方法用于彌補組合繼承中屬性方法覆蓋的問題。

用上圖代碼代替組合繼承中 Son.prototype=new Father(); 這段代碼。這樣只需調用一次父類型的構造函數(shù),避免了創(chuàng)造多余不必要的屬性方法,并且保持了原型鏈不改變,是一種理想的引用類型繼承方法。

關于js繼承模式先粗略給大家介紹這么多,相信對大家有所幫助,更多信息請繼續(xù)關注腳本之家網(wǎng)站。

相關文章

  • js模擬實現(xiàn)煙花特效

    js模擬實現(xiàn)煙花特效

    這篇文章主要為大家詳細介紹了js模擬實現(xiàn)煙花特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • JavaScript canvas實現(xiàn)加載圖片

    JavaScript canvas實現(xiàn)加載圖片

    這篇文章主要為大家詳細介紹了JavaScript canvas實現(xiàn)加載圖片,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 中級前端工程師必須要掌握的27個JavaScript 技巧(干貨總結)

    中級前端工程師必須要掌握的27個JavaScript 技巧(干貨總結)

    這篇文章主要介紹了中級前端工程師必須要掌握的27個JavaScript 技巧(干貨總結),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-09-09
  • 微信小程序開發(fā)之實現(xiàn)一個跑步小程序

    微信小程序開發(fā)之實現(xiàn)一個跑步小程序

    本文將開發(fā)一個簡易的微信跑步小程序,用到的方法是wx.onLocationChange,可以監(jiān)聽實時地理位置變化事件,感興趣的小伙伴可以了解一下
    2022-08-08
  • JavaScript實現(xiàn)答題評分功能頁面

    JavaScript實現(xiàn)答題評分功能頁面

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)答題評分功能頁面,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • JS操作json對象key、value的常用方法分析

    JS操作json對象key、value的常用方法分析

    這篇文章主要介紹了JS操作json對象key、value的常用方法,結合實例形式分析了js操作json對象鍵值對遍歷及增刪的相關操作技巧,需要的朋友可以參考下
    2019-10-10
  • javascript內嵌式與外鏈式的基本應用方式

    javascript內嵌式與外鏈式的基本應用方式

    這篇文章主要介紹了javascript內嵌式與外鏈式的基本應用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 微信小程序轉換uniapp的遷移步驟以及遇到的問題總結

    微信小程序轉換uniapp的遷移步驟以及遇到的問題總結

    最近公司有個需求,第一次遇到,把原生的微信小程序代碼轉換為uni-app項目,下面這篇文章主要給大家介紹了關于微信小程序轉換uniapp的遷移步驟以及遇到問題的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 基于百度地圖api清除指定覆蓋物(Overlay)的方法

    基于百度地圖api清除指定覆蓋物(Overlay)的方法

    下面小編就為大家分享一篇基于百度地圖api清除指定覆蓋物(Overlay)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • js去字符串前后空格的實現(xiàn)方法

    js去字符串前后空格的實現(xiàn)方法

    這篇文章主要介紹了js去字符串前后空格的實現(xiàn)方法,重點推薦使用正則的方式,感興趣的小伙伴們可以參考一下
    2016-02-02

最新評論