I am trying to run the following code:
I pass parameter to a function, but it always has the value of the last object run through the loop. I read some articles abou
It is a scope problem. By the time the event handler function is executed, the value of parentId
has changed and is not longer what you expected.
This can be solved making the original event handler function be returned by another function which, in turn, is passed the value of parentId
as argument:
function getEventHandlerFunction(id){
return function() {
alert(id); // variable found in the closure with the expected value
};
}
aDisplayCol.bind('click', getEventHandlerFunction(parentId));
Perhaps there's a problem with using parentId
in the callback.
Try alert(parents[i]['PARENT_ID']);
.
EDIT: Let's see if we can get around our scope issues with .data().
aDisplayCol.data("parentId",parents[i]['PARENT_ID']);
aDisplayCol.click(function() {
alert($(this).data('parentId'));
});
You can avoid the clouseres problems with the eventData parameter of the bind function like this
var message = 'Spoon!';
$('#foo').bind('click', {msg: message}, function(event) {
alert(event.data.msg);
});
message = 'Not in the face!';
$('#bar').bind('click', {msg: message}, function(event) {
alert(event.data.msg);
});
this is from the jquery bind api documentation http://api.jquery.com/bind/#passing-event-data