js函數(shù)調(diào)用常用方法詳解
來源 javascript語言精粹。這不是書上的源代碼。
js的函數(shù)調(diào)用會免費奉送兩個而外的參數(shù)就是 this 和 arguments 。arguments是參數(shù)組,他并不是一個真實的數(shù)組,但是可以使用.length方法獲得長度。
書上有說4中調(diào)用方式:
方法調(diào)用模式
函數(shù)調(diào)用模式
構(gòu)造器調(diào)用模式
apply調(diào)用模式
下面我們來看看一些實例更好理解。
1:方法調(diào)用模式
請注意this此時指向myobject。
/*方法調(diào)用模式*/
var myobject={
value:0,
inc:function(){
alert(this.value)
}
}
myobject.inc()
2:函數(shù)調(diào)用模式
請注意this此時指向window。
/*函數(shù)調(diào)用模式*/
var add=function(a,b){
alert(this)//this被綁頂?shù)絯indow
return a+b;
}
var sum=add(3,4);
alert(sum)
3:構(gòu)造器調(diào)用模式
javascript語言精粹一書建議摒棄這中方式。因為有更好的方式。這里先不介紹。下次發(fā)表博文的時候貼出來。
會在這里加一個連接。
/*構(gòu)造器調(diào)用模式 摒棄*/
var quo=function(string){
this.status=string;
}
quo.prototype.get_status=function(){
return this.status;
}
var qq=new quo("aaa");
alert(qq.get_status());
4:apply調(diào)用模式
==我們可以來看一個更有用的apply實例??醋钕旅娴拇a。
/*apply*/
//注意使用了上面的sum函數(shù)
//與myobject
//這中調(diào)用方式的優(yōu)點在于可以指向this指向的對象。
//apply的第一個參數(shù)就是this指針要指向的對象
var arr=[10,20];
var sum=add.apply(myobject,arr);
alert(sum);
看這個apply真正應(yīng)用。bind這是一個綁定時間的函數(shù)。
var bind=function(object,type,fn){
if(object.attachEvent){//IE瀏覽器
object.attachEvent("on"+type,(function(){
return function(event){
window.event.cancelBubble=true;//停止時間冒泡
object.attachEvent=[fn.apply(object)];//----這里我要講的是這里
//在IE里用attachEvent添加一個時間綁定以后。
//this的指向不是到object對象本身所以。我們綁定的function里的this.id是無法工作的。
//但是如果我們用fn.apply(object)
//這里可以看出我們是把a(bǔ)pply的第一個對象也就是this的指向變更給了object所以this.id就變成了
//object.id 可以正常工作了。
}
})(object),false);
}else if(object.addEventListener){//其他瀏覽器
object.addEventListener(type,function(event){
event.stopPropagation();//停止時間冒泡
fn.apply(this)
});
}
}
bind(document.getElementById("aaa"),"click",function(){alert(this.id)});
相關(guān)文章
深入理解JavaScript系列(39):設(shè)計模式之適配器模式詳解
這篇文章主要介紹了深入理解JavaScript系列(39):設(shè)計模式之適配器模式詳解,適配器模式(Adapter)是將一個類(對象)的接口(方法或?qū)傩裕┺D(zhuǎn)化成客戶希望的另外一個接口(方法或?qū)傩裕?需要的朋友可以參考下2015-03-03關(guān)于js的三種使用方式(行內(nèi)js、內(nèi)部js、外部js)的程序代碼
本文主要和大家介紹關(guān)于js的三種使用方式(行內(nèi)js、內(nèi)部js、外部js)的實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家2018-05-05淺談JavaScript中的apply/call/bind和this的使用
apply/call/bind三者的聯(lián)系就在于,都可以用來改變函數(shù)中 this 指向的值,且第一個參數(shù)為要指向的 this 的值,apply的第二個參數(shù)(或 bind 與 call 的不定參數(shù))為要傳入的參數(shù)。這就不得不提及 javascript 中函數(shù)的 this 的指向了。下面我們來簡單探討下2017-02-02深入理解JavaScript系列(49):Function模式(上篇)
這篇文章主要介紹了深入理解JavaScript系列(49):Function模式(上篇),本文講解了回調(diào)函數(shù)、配置對象、返回函數(shù)、偏應(yīng)用、Currying等內(nèi)容,需要的朋友可以參考下2015-03-03