Надсилання аргументів функції зворотного виклику eventListener вимагає створення ізольованої функції та передачі аргументів на цю ізольовану функцію.
Ось приємна маленька помічна функція, яку ви можете використовувати. Спираючись на приклад "привіт, світ", наведений вище.)
Одне, що також потрібно, - це підтримувати посилання на функцію, щоб ми могли видалити слухача чисто.
// Lambda closure chaos.
//
// Send an anonymous function to the listener, but execute it immediately.
// This will cause the arguments are captured, which is useful when running
// within loops.
//
// The anonymous function returns a closure, that will be executed when
// the event triggers. And since the arguments were captured, any vars
// that were sent in will be unique to the function.
function addListenerWithArgs(elem, evt, func, vars){
var f = function(ff, vv){
return (function (){
ff(vv);
});
}(func, vars);
elem.addEventListener(evt, f);
return f;
}
// Usage:
function doSomething(withThis){
console.log("withThis", withThis);
}
// Capture the function so we can remove it later.
var storeFunc = addListenerWithArgs(someElem, "click", doSomething, "foo");
// To remove the listener, use the normal routine:
someElem.removeEventListener("click", storeFunc);