亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript面向?qū)ο笕筇卣髦鄳B(tài)實例詳解

 更新時間:2019年07月24日 10:00:24   作者:Johnny丶me  
這篇文章主要介紹了javascript面向?qū)ο笕筇卣髦鄳B(tài),結(jié)合實例形式詳細(xì)分析了javascript面向?qū)ο蟪绦蛟O(shè)計中多態(tài)的概念、原理,并結(jié)合實例形式總結(jié)了多態(tài)的實現(xiàn)方法與使用技巧,需要的朋友可以參考下

本文實例講述了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è)計有所幫助。

相關(guān)文章

最新評論