Bir eventListener öğesinin geri çağırma işlevine bağımsız değişkenler göndermek için yalıtılmış bir işlev oluşturulması ve bağımsız değişkenlerin bu yalıtılmış işleve iletilmesi gerekir.
İşte kullanabileceğiniz güzel bir küçük yardımcı işlevi. Yukarıdaki "merhaba dünya" örneğine dayanarak.)
Ayrıca ihtiyaç duyulan bir şey, dinleyiciyi temiz bir şekilde kaldırabilmemiz için işleve bir referans sağlamaktır.
// 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);