我正在尝试将一些参数传递给用作 as 的函数callback,我该怎么做?
这是我的尝试:
function tryMe(param1, param2) {
  alert(param1 + " and " + param2);
}
function callbackTester(callback, param1, param2) {
  callback(param1, param2);
}
callbackTester(tryMe, "hello", "goodbye");
我正在尝试将一些参数传递给用作 as 的函数callback,我该怎么做?
这是我的尝试:
function tryMe(param1, param2) {
  alert(param1 + " and " + param2);
}
function callbackTester(callback, param1, param2) {
  callback(param1, param2);
}
callbackTester(tryMe, "hello", "goodbye");
如果你想要更一般的东西,你可以像这样使用参数变量:
function tryMe(param1, param2) {
  alert(param1 + " and " + param2);
}
function callbackTester(callback) {
  callback(arguments[1], arguments[2]);
}
callbackTester(tryMe, "hello", "goodbye");
但除此之外,您的示例工作正常(arguments[0]可以代替callback测试仪使用)
这也可以:
// callback function
function tryMe(param1, param2) {
  alert(param1 + " and " + param2);
}
// callback executer 
function callbackTester(callback) {
  callback();
}
// test function
callbackTester(function() {
  tryMe("hello", "goodbye");
});
另一个场景:
// callback function
function tryMe(param1, param2, param3) {
  alert(param1 + " and " + param2 + " " + param3);
}
// callback executer 
function callbackTester(callback) {
  //this is the more obivous scenario as we use callback function
  //only when we have some missing value
  //get this data from ajax or compute
  var extraParam = "this data was missing";
  //call the callback when we have the data
  callback(extraParam);
}
// test function
callbackTester(function(k) {
  tryMe("hello", "goodbye", k);
});
你的问题不清楚。如果您问如何以更简单的方式执行此操作,您应该查看 ECMAScript 第 5 版方法.bind(),它是Function.prototype的成员。使用它,您可以执行以下操作:
function tryMe (param1, param2) {
    alert (param1 + " and " + param2);
}
function callbackTester (callback) {
    callback();
}
callbackTester(tryMe.bind(null, "hello", "goodbye"));
您还可以使用以下代码,如果该方法在当前浏览器中不可用,则会添加该方法:
// From Prototype.js
if (!Function.prototype.bind) { // check if native implementation available
  Function.prototype.bind = function(){ 
    var fn = this, args = Array.prototype.slice.call(arguments),
        object = args.shift(); 
    return function(){ 
      return fn.apply(object, 
        args.concat(Array.prototype.slice.call(arguments))); 
    }; 
  };
}
如果您不确定将有多少参数传递给回调函数,请使用applyfunction。
function tryMe (param1, param2) {
  alert (param1 + " and " + param2);
}
function callbackTester(callback,params){
    callback.apply(this,params);
}
callbackTester(tryMe,['hello','goodbye']);
当您有一个回调,该回调将被具有特定数量参数的代码以外的东西调用,并且您想传入额外的参数时,您可以将包装函数作为回调传递,并在包装器内部传递额外的参数。
function login(accessedViaPopup) {
    //pass FB.login a call back function wrapper that will accept the
    //response param and then call my "real" callback with the additional param
    FB.login(function(response){
        fb_login_callback(response,accessedViaPopup);
    });
}
//handles respone from fb login call
function fb_login_callback(response, accessedViaPopup) {
    //do stuff
}