Mengirim argumen ke fungsi callback eventListener membutuhkan pembuatan fungsi yang terisolasi dan meneruskan argumen ke fungsi yang terisolasi itu.
Inilah fungsi pembantu kecil yang bagus yang dapat Anda gunakan. Berdasarkan contoh "halo dunia" di atas.)
Satu hal yang juga dibutuhkan adalah mempertahankan referensi ke fungsi tersebut sehingga kita dapat menghapus pendengar dengan bersih.
// 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);