javascript 面向對象編程基礎 多態(tài)
更新時間:2009年08月21日 01:40:06 作者:
javascript 面向對象編程基礎 多態(tài) 的實現(xiàn)方法說明,大家可以看下下面的代碼。
Javascript已經可以模擬出面向對象的封裝和繼承特性,但是不幸的是Javascript對多態(tài)特性的支持非常弱!其它面向對象語言的多態(tài)一般都由方法重載和虛方法來實現(xiàn)多態(tài),Javascript也通過這兩種途徑來實現(xiàn)!
重載:由于Javascript是弱類型的語言,而且又支持可變參數(shù),當我們定義重載方法的時候,解釋器無法通過參數(shù)類型和參數(shù)個數(shù)來區(qū)分不同的重載方法,因此方法重載是不被支持的!當先后定義了同名的方法的時候,后定義的方法會覆蓋先定義的方法!
既然解釋器無法分辨重載方法,那就手動區(qū)分不同的方法:
var MyClass=function(){
var AddNum=function(a,b){
return a+b;
}
var AddString=function(a,b){
return "I am here"+a+b;
}
this.Add=function(a,b){
if(typeof(a)=="number")
return AddNum(a,b);
else
return AddString(a,b);
}
}
var MyObj = new MyClass();
var X = MyObj.Add(5,6);
var Y = MyObj.Add("A","FFFFFF");
alert(X); //結果:11
alert(Y); //結果:I am hereAFFFFFF
虛方法:
function BaseClass(){
this.Hello=function(){
return this.Say();
}
}
function MyClassA(){
this.Say=function(){
return "Hello";
}
}
function MyClassB(){
this.Say=function(){
return "This is MyClassB";
}
}
MyClassA.prototype = new BaseClass();
MyClassB.prototype = new BaseClass();
var ObjA = new MyClassA();
var XX = ObjA.Hello();
alert(XX); //結果:Hello
var ObjB = new MyClassB();
var YY = ObjB.Hello();
alert(YY); //結果:This is MyClassB
由于Javascript解釋執(zhí)行的特性,因此可以再基類中調用將要在派生類中定義的方法,那么這個基類方法就相當于虛方法,可以實現(xiàn)模擬多態(tài)!
js的重載和重寫(覆寫):
重載的意思是,“同一個名字的函數(shù)(注意這里包括函數(shù))或方法可以有多個實現(xiàn),它們依靠參數(shù)的類型和(或)參數(shù)的個數(shù)來區(qū)分識別”。而重寫(覆蓋)的意思是,“子類中可以定義與父類中同名,并且參數(shù)類型和個數(shù)也相同的方法,這些方法的定義后,在子類的實例化對象中,父類中繼承的這些同名方法將被隱藏”。重載的英文是overload,覆蓋的英文是override。好了,概念介紹到這里,你猜到我要說什么了嗎?嘿嘿,Code is cheap.看重載代碼:
// 通過函數(shù)的arguments屬性實現(xiàn)重載
function add() {
var sum = 0 ;
for ( var i = 0 ; i < arguments.length; i ++ ) {
sum += arguments[i];
}
return sum;
}
function test() {
alert(add());
alert(add( 1 , 2 ));
alert(add( 1 , 2 , 3 ));
}
通過代碼運行結果,這樣就實現(xiàn)了任意多個參數(shù)加法函數(shù)的重載了。當然,你還可以在函數(shù)中通過 instanceof 或者 constructor 來判斷每個參數(shù)的類型,來決定后面執(zhí)行什么操作,實現(xiàn)更為復雜的函數(shù)或方法重載??傊?,javascript 的重載,是在函數(shù)中由用戶自己通過操作 arguments 這個屬性來實現(xiàn)的。關于arguments的特性,前面我已經做了簡單介紹,參考拙文:http://blog.csdn.net/zhanglingdll_39/archive/2009/08/20/4465670.aspx 。
下面重點理解js重寫的實現(xiàn):
// 為類添加靜態(tài)方法inherit表示繼承于某類
Function.prototype.inherit = function (baseClass) {
for ( var p in baseClass.prototype) {
this .prototype[p] = baseClass.prototype[p];
}
}
// js實現(xiàn)重寫
function parentClass() { // 父類
}
parentClass.prototype.method = function () {
alert( " parentClass method " );
}
function subClass() { // 子類
}
//
下面這一句和subClass.prototype = new parentClass();等價
subClass.inherit(parentClass);
// subClass.prototype.method = function() { // 子類重寫了父類的方法 -- 去掉注釋運行試試看
// alert("subClass method");
// }
function test() {
var obj = new subClass();
obj.method();
}
這樣,子類中定義的method 就覆蓋了從父類中繼承來的method 方法了。這是你可能會問,如何在子類中調用父類的method方法呢?好的,看實現(xiàn)如下:
// 為類添加靜態(tài)方法inherit表示繼承于某類
Function.prototype.inherit = function (baseClass) {
for ( var p in baseClass.prototype) {
this .prototype[p] = baseClass.prototype[p];
}
}
/* 參考文章:http://menjoy.javaeye.com/blog/127847 */
// js實現(xiàn)重寫
function parentClass() {
this .method = function () {
alert( " parentClass method " );
}
}
function subClass() {
var method = this .method;
this .method = function () {
method.call( this );
alert( " subClass method " );
}
}
subClass.prototype = new parentClass();
// subClass.inherit(parentClass); //這一句貌似和上一句subClass.prototype = new parentClass();等價,其實呢????(注釋上一行,運行這一行看看)
subClass.prototype.constructor = subClass;
function test() {
var obj = new subClass();
obj.method();
}
好了,關于多態(tài)的介紹就到這里。js面向對象編程猶如浩瀚海洋廣闊無邊,我這三篇參考別人的文章寫出來的js面向對象基礎只能當作入門者學習的參考。學無止境,參考了網上幾篇老大們的牛文,深知自身技術的淺薄,對于已經超越了解階段的讀者,還是看看園子里高人的技術文章吧。我這里要先拜謝園子里的高人了。
重載:由于Javascript是弱類型的語言,而且又支持可變參數(shù),當我們定義重載方法的時候,解釋器無法通過參數(shù)類型和參數(shù)個數(shù)來區(qū)分不同的重載方法,因此方法重載是不被支持的!當先后定義了同名的方法的時候,后定義的方法會覆蓋先定義的方法!
既然解釋器無法分辨重載方法,那就手動區(qū)分不同的方法:
復制代碼 代碼如下:
var MyClass=function(){
var AddNum=function(a,b){
return a+b;
}
var AddString=function(a,b){
return "I am here"+a+b;
}
this.Add=function(a,b){
if(typeof(a)=="number")
return AddNum(a,b);
else
return AddString(a,b);
}
}
var MyObj = new MyClass();
var X = MyObj.Add(5,6);
var Y = MyObj.Add("A","FFFFFF");
alert(X); //結果:11
alert(Y); //結果:I am hereAFFFFFF
虛方法:
復制代碼 代碼如下:
function BaseClass(){
this.Hello=function(){
return this.Say();
}
}
function MyClassA(){
this.Say=function(){
return "Hello";
}
}
function MyClassB(){
this.Say=function(){
return "This is MyClassB";
}
}
MyClassA.prototype = new BaseClass();
MyClassB.prototype = new BaseClass();
var ObjA = new MyClassA();
var XX = ObjA.Hello();
alert(XX); //結果:Hello
var ObjB = new MyClassB();
var YY = ObjB.Hello();
alert(YY); //結果:This is MyClassB
由于Javascript解釋執(zhí)行的特性,因此可以再基類中調用將要在派生類中定義的方法,那么這個基類方法就相當于虛方法,可以實現(xiàn)模擬多態(tài)!
js的重載和重寫(覆寫):
重載的意思是,“同一個名字的函數(shù)(注意這里包括函數(shù))或方法可以有多個實現(xiàn),它們依靠參數(shù)的類型和(或)參數(shù)的個數(shù)來區(qū)分識別”。而重寫(覆蓋)的意思是,“子類中可以定義與父類中同名,并且參數(shù)類型和個數(shù)也相同的方法,這些方法的定義后,在子類的實例化對象中,父類中繼承的這些同名方法將被隱藏”。重載的英文是overload,覆蓋的英文是override。好了,概念介紹到這里,你猜到我要說什么了嗎?嘿嘿,Code is cheap.看重載代碼:
復制代碼 代碼如下:
// 通過函數(shù)的arguments屬性實現(xiàn)重載
function add() {
var sum = 0 ;
for ( var i = 0 ; i < arguments.length; i ++ ) {
sum += arguments[i];
}
return sum;
}
function test() {
alert(add());
alert(add( 1 , 2 ));
alert(add( 1 , 2 , 3 ));
}
通過代碼運行結果,這樣就實現(xiàn)了任意多個參數(shù)加法函數(shù)的重載了。當然,你還可以在函數(shù)中通過 instanceof 或者 constructor 來判斷每個參數(shù)的類型,來決定后面執(zhí)行什么操作,實現(xiàn)更為復雜的函數(shù)或方法重載??傊?,javascript 的重載,是在函數(shù)中由用戶自己通過操作 arguments 這個屬性來實現(xiàn)的。關于arguments的特性,前面我已經做了簡單介紹,參考拙文:http://blog.csdn.net/zhanglingdll_39/archive/2009/08/20/4465670.aspx 。
下面重點理解js重寫的實現(xiàn):
// 為類添加靜態(tài)方法inherit表示繼承于某類
Function.prototype.inherit = function (baseClass) {
for ( var p in baseClass.prototype) {
this .prototype[p] = baseClass.prototype[p];
}
}
// js實現(xiàn)重寫
function parentClass() { // 父類
}
parentClass.prototype.method = function () {
alert( " parentClass method " );
}
function subClass() { // 子類
}
//
復制代碼 代碼如下:
下面這一句和subClass.prototype = new parentClass();等價
subClass.inherit(parentClass);
// subClass.prototype.method = function() { // 子類重寫了父類的方法 -- 去掉注釋運行試試看
// alert("subClass method");
// }
function test() {
var obj = new subClass();
obj.method();
}
這樣,子類中定義的method 就覆蓋了從父類中繼承來的method 方法了。這是你可能會問,如何在子類中調用父類的method方法呢?好的,看實現(xiàn)如下:
// 為類添加靜態(tài)方法inherit表示繼承于某類
Function.prototype.inherit = function (baseClass) {
for ( var p in baseClass.prototype) {
this .prototype[p] = baseClass.prototype[p];
}
}
/* 參考文章:http://menjoy.javaeye.com/blog/127847 */
// js實現(xiàn)重寫
function parentClass() {
this .method = function () {
alert( " parentClass method " );
}
}
function subClass() {
var method = this .method;
this .method = function () {
method.call( this );
alert( " subClass method " );
}
}
subClass.prototype = new parentClass();
// subClass.inherit(parentClass); //這一句貌似和上一句subClass.prototype = new parentClass();等價,其實呢????(注釋上一行,運行這一行看看)
subClass.prototype.constructor = subClass;
function test() {
var obj = new subClass();
obj.method();
}
好了,關于多態(tài)的介紹就到這里。js面向對象編程猶如浩瀚海洋廣闊無邊,我這三篇參考別人的文章寫出來的js面向對象基礎只能當作入門者學習的參考。學無止境,參考了網上幾篇老大們的牛文,深知自身技術的淺薄,對于已經超越了解階段的讀者,還是看看園子里高人的技術文章吧。我這里要先拜謝園子里的高人了。
您可能感興趣的文章:
- JavaScript面向對象三個基本特征實例詳解【封裝、繼承與多態(tài)】
- JS面向對象基礎講解(工廠模式、構造函數(shù)模式、原型模式、混合模式、動態(tài)原型模式)
- Javascript 面向對象(一)(共有方法,私有方法,特權方法)
- 面向對象的Javascript之二(接口實現(xiàn)介紹)
- js面向對象之常見創(chuàng)建對象的幾種方式(工廠模式、構造函數(shù)模式、原型模式)
- javascript 面向對象全新理練之數(shù)據(jù)的封裝
- 徹底理解js面向對象之繼承
- JavaScript面向對象編程入門教程
- JS 面向對象的5鐘寫法
- js面向對象之靜態(tài)方法和靜態(tài)屬性實例分析
- JavaScript面向對象之七大基本原則實例詳解
相關文章
Javascript面向對象編程(三) 非構造函數(shù)的繼承
這個系列的第一部分介紹了"封裝",第二部分介紹了使用構造函數(shù)實現(xiàn)"繼承"。2011-08-08JavaScript 類的定義和引用 JavaScript高級培訓 自定義對象
在Java語言中,我們可以定義自己的類,并根據(jù)這些類創(chuàng)建對象來使用,在Javascript中,我們也可以定義自己的類,例如定義User類、Hashtable類等等。2010-04-04