javascript中的回調函數中變量作用域

1,在callObjMethod方法中,我用了兩種方式回調“method"方法: 
第一種方式:method("通過默認上下文回調"); 
沒有指定上下文,我們發現回調函數內部訪問context的值是全局變量的值, 
這說明,執行該方法的默認上下文是全局上下文。 
第二種方式:method.call(obj,"指定顯式對象上下文回調"); 
指定obj爲method執行的上下文,就能夠訪問到對象內部的context

 

2,在javascript中,在function內部創建一個function的時候,會自動創建一個closure, 

而這個closure就能記住對應的function創建時的上下文

 

3,在javascript中,this也可以代表當前對象,但不能直接用在匿名function中用,比如: 

JScript code var testObj={ context:"初始", callback:function (str){//回調函數 alert("callback:我所處的上下文中,context="+this.context+",我被回調的方式:"+str); }, caller:function(){ callWithClosure(function(param){this.callback(param);}); } };//創建一個對象,作爲測試回調函數的上下文 
以上代碼中的this指的不是testObj,而是全局上下文, 需要在closure外寫一個臨時變量來代表this,完整的代碼如下:

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章