在我的整个脚本中,我都在调用函数dynamo.toolbox.add_temp_button
。一个例子在这里:
if(page < total_pages){
dynamo.toolbox.add_temp_button("Next Page",function(){
dynamo.shop.enter.access(page+1,data.shop_zbid);
});
}
正如您在此调用中看到的那样,传递了两个参数,page+1
并且data.shop_zbid
. 现在这些值不是常量,并且由于脚本的整体功能而迅速变化。
现在这是函数本身:
add_temp_button : function(text,callback){
var id = text.toLowerCase().replace(/[^A-Za-z_]/g,"_");
callback = callback !== undefined && callback !== null ? callback : function(){};
var but = '<button value="'+text+'" id="jqi_state0_button'+id+'" name="jqi_state0_button'+id+'" class="dynamo_temp_button">'+text+'</button>';
$("#jqi_state0_buttonClose").before(but);
$("#jqi_state0_button"+id).bind('click',callback);
},
请注意,这已从我的脚本中删除,但它由dynamo.toolbox.add_temp_button
.
现在,我需要知道这是否形成了一个闭包,即我传递给add_temp_button
函数的参数的值是否会一成不变?
我最担心的是第二个参数,callback
. 这是一个作为回调函数传递给的函数$.bind
。当绑定事件被触发时,它会使用 and 的当前值page
,callback
还是最初传递的值?
谢谢!