I’ve been searching for hours for a solution to this problem. I’m creating a table using prototype.js 1.6.0.1 and am having trouble with the this object in context with the .each function. here is a snippit.
var Table = Class.create({
initialize : function(id) {
this.elmnt = $(id);
this.rows = [];
},
initRows : function() {
$A(this._elmnt.tBodies).each(function(body) {
$A(body.rows).each(function(row) {
//right here is where i would like to call
// this.rows.push(row);
console.log(this); // prints DOMWindow
});
});
}
});
As you can see inside the second .each function this resolves to DOMWindow. I would like to be able to call this.rows.push(row) but I can’t as “this” isn’t resolving as expected.
Any help would be appreciated. I know i could do the standard (i=0; i < length; i++) loop but I was trying to make this a little cleaner. Thanks for any guidance you can offer.
The easiest way to work around this is to save
thisat the start ofinitRowsand refer to in within theeachfunctionsThe problem you’re running into is that
thiscan be manipulated by the caller of the function. It’s very common in callbacks to setthisto an element which is relevant to the call back. In the case ofeachit’s set to the element for the current iteration of the value.The
selftrick works because it saves thethisas it’s bound in the functioninitRowsand then uses that saved value in the iteration.