Friday, May 10, 2024
 Popular · Latest · Hot · Upcoming
124
rated 0 times [  131] [ 7]  / answers: 1 / hits: 32735  / 16 Years ago, thu, february 26, 2009, 12:00:00

I have a method that uses the setTimeout function and makes a call to another method. On initial load method 2 works fine. However, after the timeout, I get an error that says method2 is undefined. What am I doing wrong here?



ex:



test.prototype.method = function()
{
//method2 returns image based on the id passed
this.method2('useSomeElement').src = http://www.some.url;
timeDelay = window.setTimeout(this.method, 5000);
};

test.prototype.method2 = function(name) {
for (var i = 0; i < document.images.length; i++) {
if (document.images[i].id.indexOf(name) > 1) {
return document.images[i];
}
}
};

More From » javascript

 Answers
9

The issue is that setTimeout() causes javascript to use the global scope. Essentially, you're calling the method() class, but not from this. Instead you're just telling setTimeout to use the function method, with no particular scope.



To fix this you can wrap the function call in another function call that references the correct variables. It will look something like this:



test.protoype.method = function()
{
var that = this;

//method2 returns image based on the id passed
this.method2('useSomeElement').src = http://www.some.url;

var callMethod = function()
{
that.method();
}

timeDelay = window.setTimeout(callMethod, 5000);
};


that can be this because callMethod() is within method's scope.



This problem becomes more complex when you need to pass parameters to the setTimeout method, as IE doesn't support more than two parameters to setTimeout. In that case you'll need to read up on closures.



Also, as a sidenote, you're setting yourself up for an infinite loop, since method() always calls method().


[#99923] Thursday, February 19, 2009, 16 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
grayson

Total Points: 36
Total Questions: 113
Total Answers: 95

Location: Tonga
Member since Fri, Aug 21, 2020
4 Years ago
grayson questions
;