简体   繁体   English

将参数传递给回调函数

[英]Pass arguments to a callback function

By default I cannot pass arguments to a callback function 默认情况下,我无法将参数传递给回调函数

 function callback() { alert('Hi human'); } var x = 1, y = 2;//Pass arguments(x,y) to a callback function document.getElementById('someelem').addEventListener('click', callback); 
 <button id="someelem">Ok</button> 

document.getElementById('someelem').addEventListener('click', function(event) {
    callback(x, y, e);
});

Another way is to bind function 另一种方法是绑定功能

document.getElementById('someelem').addEventListener('click', callback.bind(null, x, y));

You could create it as an anonymous function like so: 您可以将其创建为匿名函数,如下所示:

var x = 1, y = 2;//Pass arguments(x,y) to a callback function

document.getElementById('someelem').addEventListener('click', function(x, y) {
   alert('Hi human');
});

You can use bind to overcome the issue. 您可以使用bind来解决此问题。

 function callback(x, y) { console.log(this,x,y); } var x = 1, y = 2; //Pass arguments(x,y) to a callback function var el = document.getElementById('someelem'); el.addEventListener('click', callback.bind(el, x, y)); 
 <button id="someelem">OK</button> 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM