本文實(shí)例講述了javascript面向?qū)ο笕筇卣髦鄳B(tài)。分享給大家供大家參考,具體如下:
成都創(chuàng)新互聯(lián)公司于2013年開始,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站制作、成都網(wǎng)站制作網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢想脫穎而出為使命,1280元萊蕪做網(wǎng)站,已為上家服務(wù),為萊蕪各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:028-86922220
多態(tài)
從某種意義上來說,多態(tài)是面向?qū)ο笾兄匾囊徊糠郑彩菍?shí)施繼承的主要目的。
一個(gè)實(shí)例可以擁有多個(gè)類型,它既可以是這種類型,也可以是那種類型,這種多種狀態(tài)被稱為類的多態(tài)。
多態(tài)的表現(xiàn)形式很多,其中繼承和重載都是多態(tài)的表現(xiàn)形式。
——整理自《jQuery開發(fā)從入門到精通》
繼承
繼承本身是多態(tài)的一種實(shí)現(xiàn)。詳情請參考前面一篇:https://www.jb51.net/article/166097.htm
重載
重載也是多態(tài)的一種體現(xiàn)。重載就是同名方法的多個(gè)實(shí)現(xiàn)。依靠參數(shù)的類型和參數(shù)的個(gè)數(shù)來區(qū)分和識別。在js中,函數(shù)的參數(shù)是沒有類型的,并且參數(shù)的個(gè)數(shù)是任意的。
例如:下面的add函數(shù)
function add(x,y){ return x+y; }
我們將其實(shí)現(xiàn)重載
function add(){ var sum = 0; for(var i=0; i<arguments.length; i++) { if(typeof arguments[i] === 'number') { sum += arguments[i]; } } return sum; }
這樣,不管參數(shù)類型如何,該函數(shù)會(huì)自動(dòng)把數(shù)值類型參數(shù)相加并返回總數(shù)。
另外,結(jié)合instanceof 和constructor屬性來判斷每個(gè)參數(shù)類型,以決定根據(jù)參數(shù)個(gè)數(shù)和類型執(zhí)行不同操作,這樣可以實(shí)現(xiàn)更復(fù)雜的重載。
下面我們使用js的原型來設(shè)計(jì)類的多態(tài)特征。
function A(){ this.get = function(){ console.log('A'); } } function B(){ this.get = function(){ console.log('B'); } } B.prototype = new A(); // 使用原型繼承,讓B類繼承A類 function C(){ this.get = function(){ console.log('C'); } } C.prototype = new A(); // 使用原型繼承,讓B類繼承A類 function F(x){ this.x = x; } F.prototype.get = function(){ // 判斷是否為A類的實(shí)例 if(this.x instanceof A){ // 如果是,調(diào)用實(shí)例的方法 this.x.get(); } } // 下面開始 var b = new B(); var c = new C(); var f1 = new F(b); // 此時(shí)F中的this.x 就是b了, 而b是A的一個(gè)實(shí)例 var f2 = new F(c); // 原理同上 f1.get(); // B f2.get(); // C
上面的類F就包含了一個(gè)多態(tài)方法get() ,它能夠根據(jù)不同實(shí)例,來執(zhí)行不同方法。
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
網(wǎng)頁名稱:javascript面向?qū)ο笕筇卣髦鄳B(tài)實(shí)例詳解
地址分享:http://www.chinadenli.net/article8/ighoop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、動(dòng)態(tài)網(wǎng)站、外貿(mào)建站、做網(wǎng)站、網(wǎng)站收錄、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)