中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 重溫Javascript繼承機制
:nth-child 和 :nth-type-of 的區(qū)別 回到列表 有用的:nth-child秘方
 重溫Javascript繼承機制

作者:瓜瓜 時間: 2011-07-04 文檔類型:合作網(wǎng)站提供 來自:阿里媽媽UED

第 1 頁 重溫Javascript繼承機制 [1]
第 2 頁 重溫Javascript繼承機制 [2]
第 3 頁 重溫Javascript繼承機制 [3]
第 4 頁 重溫Javascript繼承機制 [4]

三、構(gòu)造函數(shù)如何實現(xiàn)繼承

現(xiàn)在有一個”MED”對象的構(gòu)造函數(shù)(MED:Marketing Experience Design,營銷體驗設(shè)計)

function MED(){
 this.aim = "營銷體驗設(shè)計";
}

依然是”WD”對象的構(gòu)造函數(shù),

function WD(skill,sex){
 this.skill = skill;
 this.sex = sex;
}

怎樣才能使”WD”繼承”MED”呢?

1. apply綁定構(gòu)造函數(shù)實現(xiàn)

最簡單的方法,大概就是使用call或apply方法,將父對象的構(gòu)造函數(shù)綁定在子對象上,也就是在子對象構(gòu)造函數(shù)中加一行:

function WD(skill,sex){

 MED.apply(this, arguments);

 this.skill = skill;
 this.sex = sex;
}

var WD1 = new WD("Html","男");
console.log(WD1.aim); // "營銷體驗設(shè)計"

2. prototype模式實現(xiàn)

我們通常的做法是使用prototype屬性。如果”WD”的prototype對象,指向一個MED的實例,那么所有”WD”的實例,就能繼承MED了。

WD.prototype = new MED();//我們將WD的prototype對象指向一個MED的實例。
WD.prototype.constructor = WD;
var WD1 = new WD("Html","男");
console.log(WD1.aim); // 營銷體驗設(shè)計

這句

WD.prototype = new MED();

相當(dāng)于完全刪除了prototype 對象原先的值,然后賦予一個新值。那么第二行又是什么意思呢?

WD.prototype.constructor = WD;

原來,任何一個prototype對象都有一個constructor屬性,指向它的構(gòu)造函數(shù)。也就是說,WD.prototype 這個對象的constructor屬性,是指向WD的。
我們在前一步已經(jīng)刪除了這個prototype對象原來的值,所以新的prototype對象沒有constructor屬性,需要我們手動加上去,否則后面的”繼承鏈”會出問題。這就是第二行的意思。
注意,這是很重要的一點,編程時務(wù)必要遵守,下文都遵循這一點,即如果替換了prototype對象,

o.prototype = {};

那么,下一步必然是為新的prototype對象加上constructor屬性,并將這個屬性指回原來的構(gòu)造函數(shù)。

o.prototype.constructor = o;

3. 從prototype直接繼承實現(xiàn)

由于MED對象中,不變的屬性都可以直接寫入MED.prototype。所以,我們也可以讓W(xué)D()跳過 MED(),直接繼承MED.prototype。
現(xiàn)在,我們先將MED對象改寫:

function MED(){ }

MED.prototype.skill = "MED";

然后,將WD的prototype對象指向MED的prototype對象,這樣就完成了繼承。

WD.prototype = MED.prototype;
WD.prototype.constructor = WD;

var WD1 = new WD("Html","男");

console.log(WD1.skill); // MED

與前一種方法相比,這樣做的優(yōu)點是效率比較高(不用執(zhí)行和建立MED的實例了),比較省內(nèi)存。缺點是 WD.prototype和MED.prototype現(xiàn)在指向了同一個對象,那么任何對WD.prototype的修改,都會反映到MED.prototype。
所以,上面這一段代碼其實是有問題的。請看第二行

WD.prototype.constructor = WD;

這一句實際上把MED.prototype對象的constructor屬性也改掉了!

console.log(MED.prototype.constructor); // WD

4. 利用一個空對象作為中介來實現(xiàn)

由于”直接繼承prototype”存在上述的缺點,所以可以利用一個空對象作為中介。

var F = function(){};
F.prototype = MED.prototype;

WD.prototype = new F();
WD.prototype.constructor = WD;

F是空對象,所以幾乎不占內(nèi)存。這時,修改WD的prototype對象,就不會影響到MED的prototype對象。

console.log(MED.prototype.constructor); // MED

5.利用 prototype模式的封裝函數(shù)

我們將上面的方法,封裝成一個函數(shù),便于使用。

function extend(Child, Parent) {

 var F = function(){};

 F.prototype = Parent.prototype;
 Child.prototype = new F();
 Child.prototype.constructor = Child;
}

使用的時候,方法如下

extend(WD,MED);
var WD1 = new WD("Html","男");
console.log(WD1.aim); // 營銷體驗設(shè)計

這個extend函數(shù)就是YUI庫如何實現(xiàn)繼承的方法。

6. 拷貝繼承實現(xiàn)

上面是采用prototype方式來實現(xiàn)繼承。其實既然子對象會擁有父對象的屬性和方法,我們直接采用”拷貝”方法也可以達(dá)到效果。簡單說,如果把父對象的所有屬性和方法,拷貝進(jìn)子對象,不也能夠?qū)崿F(xiàn)繼承嗎?
首先,還是把MED的所有不變屬性,都放到它的prototype對象上。

function MED(){}

MED.prototype.aim = "營銷體驗設(shè)計";

然后,再寫一個函數(shù),實現(xiàn)屬性拷貝的目的。

function extendCopy(Child, Parent) {
 var p = Parent.prototype;
 var c = Child.prototype;
 for (var i in p) {
  c[i] = p[i];
 }
}

這個函數(shù)的作用,就是將父對象的prototype對象中的屬性,一一拷貝給Child對象的prototype對象。
使用的時候,這樣寫:

extendCopy(WD, MED);
var WD1 = new WD("Html","男");
console.log(WD1.aim); // 營銷體驗設(shè)計

出處:阿里媽媽UED
責(zé)任編輯:bluehearts

上一頁 重溫Javascript繼承機制 [2] 下一頁 重溫Javascript繼承機制 [4]

◎進(jìn)入論壇網(wǎng)頁制作、WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章 更多相關(guān)鏈接
再談javascript圖片預(yù)加載技術(shù)
如何編寫高質(zhì)量的Javascript代碼
加載 Javascript 最佳實踐
GC與JS內(nèi)存泄露
HTML,CSS和JavaScript速查表
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻(xiàn),送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:3/41個記錄/頁 轉(zhuǎn)到 頁 共4個記錄

藍(lán)色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2