on a website i want to do this: (simplified)
myHandlers = new Array();
for(var i = 0; i < 7; i++) {
myHandlers.push(new Handler({
handlerName: 'myHandler'+i, // works, e.g. ->myHandler1, 2, 3 etc.
handlerFunc: function(bla) { /*...*/ alert(i); } // doesn't work,all return 7
}
}
I could set the counter as another attribute of my Handler (which would copy the current value) and use it inside my function, but I guess, there is also a way to actually copy this value, no?
When handlerFunc is called, the
iinside the function refers to theiof theforloop. But thatidoes probably not have the same value any more.Use a closure to bind the current value of
iin the scope of an anonymous function:Here an anonymous function
(function(i) { … })(i)is used and called immediately. This function binds the value ofiof theforloop to the locali. Thatiis then independent from theiof theforloop.