js 函數(shù)調(diào)用模式小結(jié)
更新時(shí)間:2011年12月26日 23:11:26 作者:
在javascript中一共有四種調(diào)用模式:方法調(diào)用模式、函數(shù)調(diào)用模式、構(gòu)造器調(diào)用模式和apply調(diào)用模式。這些模式在如何初始化關(guān)鍵參數(shù)this上存在差異
方法調(diào)用模式
當(dāng)一個(gè)函數(shù)被保存為對(duì)象的一個(gè)屬性時(shí),我們稱之它為該對(duì)象的一個(gè)方法,那么this被綁定到該對(duì)象上。
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
} ,
toString : function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
}
}
alert(myObject);//[Object:myObject {value:0}]
函數(shù)調(diào)用模式
當(dāng)一個(gè)函數(shù)并非一個(gè)對(duì)象的函數(shù)時(shí),那么它被當(dāng)作一個(gè)函數(shù)來調(diào)用,this被綁定到全局對(duì)象上。這是語言設(shè)計(jì)的一個(gè)錯(cuò)誤。倘若語言設(shè)計(jì)正確,當(dāng)內(nèi)部函數(shù)調(diào)用時(shí),this應(yīng)該仍然綁定到外部函數(shù)的this變量上。如:
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
} ,
toString : function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
},
getInfo:function(){
return (function(){
return this.toString();//內(nèi)部匿名函數(shù)中this指向了全局對(duì)象window
})();
}
}
alert(myObject.getInfo());//[object Window]
當(dāng)幸運(yùn)的是,有一個(gè)很容易的解決方案:定義一個(gè)變量并給它賦值為this,那么內(nèi)部函數(shù)通過該變量訪問到指向該對(duì)象的this,如:
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
} ,
toString : function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
},
getInfo:function(){
var self=this;
return (function(){
return self.toString();//通過變量self指向myObject對(duì)象
})();
}
}
alert(myObject.getInfo());//[Object:myObject {value:0}]
構(gòu)造器調(diào)用模式
JavaScript是一門基于原型繼承的語言。這意味著對(duì)象可以直接從其他對(duì)象繼承屬性。該語言是無類別的。
如果一個(gè)函數(shù)前面帶上new來調(diào)用,那么將創(chuàng)建一個(gè)隱藏連接到該函數(shù)的prototype成員的新對(duì)象,同時(shí)this將會(huì)被綁定到構(gòu)造函數(shù)的實(shí)例上。
function MyObject(name){
this.name=name || 'MyObject';
this.value=0;
this.increment=function(num){
this.value += typeof(num) === 'number' ? num : 0;
};
this.toString=function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
}
this.target=this;
}
MyObject.prototype.getInfo=function(){
return this.toString();
}
/*
同時(shí)創(chuàng)建一個(gè)MyObject.prototype對(duì)象,myObject繼承了MyObject.prototype的所有的屬性,
this綁定到了MyObject的實(shí)例上
*/
var myObject=new MyObject();
var otherObject=new MyObject();
//alert(myObject.target===myObject);//ture
//alert(myObject.target.getInfo());//[Object:MyObject {value:0}]
myObject.increment(10);
otherObject.increment(20);
alert(myObject.value);//10
alert(otherObject.value);//20
Apply 調(diào)用模式
JavaScript是一門函數(shù)式的面向?qū)ο缶幊陶Z言,所以函數(shù)可以擁有方法。
函數(shù)的apply方法,如同該對(duì)象擁有此方法,使該對(duì)象擁有此方法。此時(shí)this指向該對(duì)象。
apply接收兩個(gè)參數(shù),第一個(gè)是要綁定的對(duì)象(this指向的對(duì)象),第二個(gè)是參數(shù)數(shù)組.
function MyObject(name){
this.name=name || 'MyObject';
this.value=0;
this.increment=function(num){
this.value += typeof(num) === 'number' ? num : 0;
};
this.toString=function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
}
this.target=this;
}
function getInfo(){
return this.toString();
}
var myObj=new MyObject();
alert(getInfo.apply(myObj));//[Object:MyObject {value:0}],this指向myObj
alert(getInfo.apply(window));//[object Window],this指向window
當(dāng)一個(gè)函數(shù)被保存為對(duì)象的一個(gè)屬性時(shí),我們稱之它為該對(duì)象的一個(gè)方法,那么this被綁定到該對(duì)象上。
復(fù)制代碼 代碼如下:
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
} ,
toString : function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
}
}
alert(myObject);//[Object:myObject {value:0}]
函數(shù)調(diào)用模式
當(dāng)一個(gè)函數(shù)并非一個(gè)對(duì)象的函數(shù)時(shí),那么它被當(dāng)作一個(gè)函數(shù)來調(diào)用,this被綁定到全局對(duì)象上。這是語言設(shè)計(jì)的一個(gè)錯(cuò)誤。倘若語言設(shè)計(jì)正確,當(dāng)內(nèi)部函數(shù)調(diào)用時(shí),this應(yīng)該仍然綁定到外部函數(shù)的this變量上。如:
復(fù)制代碼 代碼如下:
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
} ,
toString : function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
},
getInfo:function(){
return (function(){
return this.toString();//內(nèi)部匿名函數(shù)中this指向了全局對(duì)象window
})();
}
}
alert(myObject.getInfo());//[object Window]
當(dāng)幸運(yùn)的是,有一個(gè)很容易的解決方案:定義一個(gè)變量并給它賦值為this,那么內(nèi)部函數(shù)通過該變量訪問到指向該對(duì)象的this,如:
復(fù)制代碼 代碼如下:
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
} ,
toString : function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
},
getInfo:function(){
var self=this;
return (function(){
return self.toString();//通過變量self指向myObject對(duì)象
})();
}
}
alert(myObject.getInfo());//[Object:myObject {value:0}]
構(gòu)造器調(diào)用模式
JavaScript是一門基于原型繼承的語言。這意味著對(duì)象可以直接從其他對(duì)象繼承屬性。該語言是無類別的。
如果一個(gè)函數(shù)前面帶上new來調(diào)用,那么將創(chuàng)建一個(gè)隱藏連接到該函數(shù)的prototype成員的新對(duì)象,同時(shí)this將會(huì)被綁定到構(gòu)造函數(shù)的實(shí)例上。
復(fù)制代碼 代碼如下:
function MyObject(name){
this.name=name || 'MyObject';
this.value=0;
this.increment=function(num){
this.value += typeof(num) === 'number' ? num : 0;
};
this.toString=function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
}
this.target=this;
}
MyObject.prototype.getInfo=function(){
return this.toString();
}
/*
同時(shí)創(chuàng)建一個(gè)MyObject.prototype對(duì)象,myObject繼承了MyObject.prototype的所有的屬性,
this綁定到了MyObject的實(shí)例上
*/
var myObject=new MyObject();
var otherObject=new MyObject();
//alert(myObject.target===myObject);//ture
//alert(myObject.target.getInfo());//[Object:MyObject {value:0}]
myObject.increment(10);
otherObject.increment(20);
alert(myObject.value);//10
alert(otherObject.value);//20
Apply 調(diào)用模式
JavaScript是一門函數(shù)式的面向?qū)ο缶幊陶Z言,所以函數(shù)可以擁有方法。
函數(shù)的apply方法,如同該對(duì)象擁有此方法,使該對(duì)象擁有此方法。此時(shí)this指向該對(duì)象。
apply接收兩個(gè)參數(shù),第一個(gè)是要綁定的對(duì)象(this指向的對(duì)象),第二個(gè)是參數(shù)數(shù)組.
復(fù)制代碼 代碼如下:
function MyObject(name){
this.name=name || 'MyObject';
this.value=0;
this.increment=function(num){
this.value += typeof(num) === 'number' ? num : 0;
};
this.toString=function(){
return '[Object:'+this.name+' {value:'+this.value+'}]';
}
this.target=this;
}
function getInfo(){
return this.toString();
}
var myObj=new MyObject();
alert(getInfo.apply(myObj));//[Object:MyObject {value:0}],this指向myObj
alert(getInfo.apply(window));//[object Window],this指向window
您可能感興趣的文章:
- JS函數(shù)的定義與調(diào)用方法推薦
- setinterval()與clearInterval()JS函數(shù)的調(diào)用方法
- js中匿名函數(shù)的創(chuàng)建與調(diào)用方法分析
- JavaScript函數(shù)的4種調(diào)用方法詳解
- javascript中聲明函數(shù)的方法及調(diào)用函數(shù)的返回值
- JavaScript函數(shù)的調(diào)用以及參數(shù)傳遞
- JavaScript中5種調(diào)用函數(shù)的方法
- 淺談js函數(shù)三種定義方式 & 四種調(diào)用方式 & 調(diào)用順序
- js函數(shù)調(diào)用的方式
- js函數(shù)調(diào)用常用方法詳解
- JavaScript函數(shù)的4種調(diào)用方法實(shí)例分析
相關(guān)文章
javascript 混合的構(gòu)造函數(shù)和原型方式,動(dòng)態(tài)原型方式
JS編程中最常用兩種對(duì)象類定義的方式。不管是利用下面2種方式的那一種,都可以達(dá)到相同的效果!2009-12-12編寫可維護(hù)面向?qū)ο蟮腏avaScript代碼[翻譯]
編寫可維護(hù)面向?qū)ο蟮腏avaScript代碼[翻譯],學(xué)習(xí)js面向?qū)ο缶帉懙呐笥芽梢詤⒖枷隆?/div> 2011-02-02javascript 面向?qū)ο缶幊袒A(chǔ) 多態(tài)
javascript 面向?qū)ο缶幊袒A(chǔ) 多態(tài) 的實(shí)現(xiàn)方法說明,大家可以看下下面的代碼。2009-08-08JavaScript 對(duì)象鏈?zhǔn)讲僮鳒y試代碼
自從使用了jQuery以后,對(duì)它的鏈?zhǔn)讲僮骱苁且蕾?,以至于常常覺得其他庫不好用。。2010-04-04JavaScript 設(shè)計(jì)模式之組合模式解析
“組合模式”顧名思意就是將多種實(shí)現(xiàn)組合在一起而達(dá)到牽一處而動(dòng)全身的效果。2010-04-04JavaScript面象對(duì)象設(shè)計(jì)
學(xué)習(xí)js的高境界就是使用面向?qū)ο蟮姆椒?,?shí)現(xiàn)js的調(diào)用2008-04-04最新評(píng)論