1

在我的整个脚本中,我都在调用函数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 的当前值pagecallback还是最初传递的值?

谢谢!

4

1 回答 1

1

改变

if(page < total_pages){
    dynamo.toolbox.add_temp_button("Next Page",function(){
        dynamo.shop.enter.access(page+1,data.shop_zbid);
    });
}

if(page < total_pages){
    dynamo.toolbox.add_temp_button("Next Page",(function(a,b){
        return function() { dynamo.shop.enter.access(a,b); }
    })(page+1,data.shop_zbid));
}

你会得到你想要的 - 你需要为回调设置page+1data.shop_zbid本地的值以获得所需的效果,否则可以在回调范围之外修改它们,然后再调用回调

于 2012-08-27T18:26:06.293 回答