javascript面向?qū)ο笕筇卣髦鄳B(tài)實(shí)例詳解
本文實(shí)例講述了javascript面向?qū)ο笕筇卣髦鄳B(tài)。分享給大家供大家參考,具體如下:
多態(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)。詳情請(qǐng)參考前面一篇:http://www.dhdzp.com/article/166097.htm
重載
重載也是多態(tài)的一種體現(xiàn)。重載就是同名方法的多個(gè)實(shí)現(xiàn)。依靠參數(shù)的類型和參數(shù)的個(gè)數(shù)來區(qū)分和識(shí)別。在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測(cè)試上述代碼運(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é)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JavaScript面向?qū)ο蟪绦蛟O(shè)計(jì)中對(duì)象的定義和繼承詳解
- javascript面向?qū)ο蟪绦蛟O(shè)計(jì)實(shí)踐常用知識(shí)點(diǎn)總結(jié)
- javascript面向?qū)ο髣?chuàng)建對(duì)象的方式小結(jié)
- javascript面向?qū)ο笕筇卣髦^承實(shí)例詳解
- javascript面向?qū)ο笕筇卣髦庋b實(shí)例詳解
- Javascript 面向?qū)ο螅ㄒ唬?共有方法,私有方法,特權(quán)方法)
- 面向?qū)ο蟮腏avascript之二(接口實(shí)現(xiàn)介紹)
- js面向?qū)ο笾小⑺接?、靜態(tài)屬性和方法詳解
- javascript面向?qū)ο笕腴T基礎(chǔ)詳細(xì)介紹
- JavaScript 面向?qū)ο蠡A(chǔ)簡(jiǎn)單示例
相關(guān)文章
JavaScript設(shè)計(jì)模式之代理模式實(shí)例分析
這篇文章主要介紹了JavaScript設(shè)計(jì)模式之代理模式,簡(jiǎn)單描述了代理模式的概念、原理并結(jié)合實(shí)例形式分析了javascript代理模式的相關(guān)實(shí)現(xiàn)與使用技巧,需要的朋友可以參考下2019-01-01
JavaScript 消息框效果【實(shí)現(xiàn)代碼】
下面小編就為大家?guī)硪黄狫avaScript 消息框效果【實(shí)現(xiàn)代碼】。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-04-04
uniapp使用百度地圖的保姆式教學(xué)(適合初學(xué)者!)
公司項(xiàng)目中有地圖展示和定位功能,所以下面這篇文章主要給大家介紹了關(guān)于uniapp使用百度地圖的保姆式教學(xué),文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03
layui form.render(''select'', ''test2'') 更新渲染的方法
今天小編就為大家分享一篇layui form.render('select', 'test2') 更新渲染的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09
在JavaScript中call()與apply()區(qū)別
這篇文章主要介紹了在JavaScript中call()與apply()區(qū)別 的相關(guān)資料,需要的朋友可以參考下2016-01-01
使用JS正則表達(dá)式 替換括號(hào),尖括號(hào)等
下面小編就為大家?guī)硪黄褂肑S正則表達(dá)式 替換括號(hào),尖括號(hào)等。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11
Javascript實(shí)現(xiàn)數(shù)組中的元素上下移動(dòng)
這篇文章主要給大家介紹了Javascript實(shí)現(xiàn)數(shù)組中的元素上下移動(dòng)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-04-04

