javascript面向?qū)ο笕筇卣髦鄳B(tài)實例詳解
本文實例講述了javascript面向?qū)ο笕筇卣髦鄳B(tài)。分享給大家供大家參考,具體如下:
多態(tài)
從某種意義上來說,多態(tài)是面向?qū)ο笾兄匾囊徊糠?,也是實施繼承的主要目的。
一個實例可以擁有多個類型,它既可以是這種類型,也可以是那種類型,這種多種狀態(tài)被稱為類的多態(tài)。
多態(tài)的表現(xiàn)形式很多,其中繼承和重載都是多態(tài)的表現(xiàn)形式。
——整理自《jQuery開發(fā)從入門到精通》
繼承
繼承本身是多態(tài)的一種實現(xiàn)。詳情請參考前面一篇:http://chabaoo.cn/article/166097.htm
重載
重載也是多態(tài)的一種體現(xiàn)。重載就是同名方法的多個實現(xiàn)。依靠參數(shù)的類型和參數(shù)的個數(shù)來區(qū)分和識別。在js中,函數(shù)的參數(shù)是沒有類型的,并且參數(shù)的個數(shù)是任意的。
例如:下面的add函數(shù)
function add(x,y){ return x+y; }
我們將其實現(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ù)會自動把數(shù)值類型參數(shù)相加并返回總數(shù)。
另外,結(jié)合instanceof 和constructor屬性來判斷每個參數(shù)類型,以決定根據(jù)參數(shù)個數(shù)和類型執(zhí)行不同操作,這樣可以實現(xiàn)更復(fù)雜的重載。
下面我們使用js的原型來設(shè)計類的多態(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類的實例 if(this.x instanceof A){ // 如果是,調(diào)用實例的方法 this.x.get(); } } // 下面開始 var b = new B(); var c = new C(); var f1 = new F(b); // 此時F中的this.x 就是b了, 而b是A的一個實例 var f2 = new F(c); // 原理同上 f1.get(); // B f2.get(); // C
上面的類F就包含了一個多態(tài)方法get() ,它能夠根據(jù)不同實例,來執(zhí)行不同方法。
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
- JavaScript面向?qū)ο蟪绦蛟O(shè)計中對象的定義和繼承詳解
- javascript面向?qū)ο蟪绦蛟O(shè)計實踐常用知識點總結(jié)
- javascript面向?qū)ο髣?chuàng)建對象的方式小結(jié)
- javascript面向?qū)ο笕筇卣髦^承實例詳解
- javascript面向?qū)ο笕筇卣髦庋b實例詳解
- Javascript 面向?qū)ο螅ㄒ唬?共有方法,私有方法,特權(quán)方法)
- 面向?qū)ο蟮腏avascript之二(接口實現(xiàn)介紹)
- js面向?qū)ο笾小⑺接?、靜態(tài)屬性和方法詳解
- javascript面向?qū)ο笕腴T基礎(chǔ)詳細(xì)介紹
- JavaScript 面向?qū)ο蠡A(chǔ)簡單示例
相關(guān)文章
contains和compareDocumentPosition 方法來確定是否HTML節(jié)點間的關(guān)系
一個很棒的 blog 文章,是 PPK 兩年前寫的,文章中解釋了 contains() 和 compareDocumentPosition() 方法運行在他們各自的瀏覽器上。2011-09-09JavaScript數(shù)組函數(shù)unshift、shift、pop、push使用實例
這篇文章主要介紹了JavaScript數(shù)組函數(shù)unshift、shift、pop、push使用實例,本文先是講解了聲明數(shù)組的方法,然后對4個函數(shù)使用給出了一些例子,需要的朋友可以參考下2014-08-08用JS操作FRAME中的IFRAME及其內(nèi)容的實現(xiàn)代碼
一直都需要這樣的東西,發(fā)現(xiàn)了這個好東西,一定要研究下2008-07-07微信小程序使用wx.chooseLocation開發(fā)地圖怎么做
這篇文章主要介紹了微信小程序使用wx.chooseLocation開發(fā)地圖流程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12弱類型語言javascript開發(fā)中的一些坑實例小結(jié)【變量、函數(shù)、數(shù)組、對象、作用域等】
這篇文章主要介紹了弱類型語言javascript開發(fā)中的一些坑,結(jié)合實例形式總結(jié)分析了javascript開發(fā)中關(guān)于變量、函數(shù)、數(shù)組、對象、作用域等相關(guān)知識點常見易錯問題,需要的朋友可以參考下2019-08-08