<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://www.theeggeadventure.com/wikimedia/index.php?action=history&amp;feed=atom&amp;title=Javascript_callback_recursion</id>
	<title>Javascript callback recursion - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://www.theeggeadventure.com/wikimedia/index.php?action=history&amp;feed=atom&amp;title=Javascript_callback_recursion"/>
	<link rel="alternate" type="text/html" href="https://www.theeggeadventure.com/wikimedia/index.php?title=Javascript_callback_recursion&amp;action=history"/>
	<updated>2026-05-16T00:04:13Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.46.0-beta</generator>
	<entry>
		<id>https://www.theeggeadventure.com/wikimedia/index.php?title=Javascript_callback_recursion&amp;diff=2066&amp;oldid=prev</id>
		<title>Egge: New page: Recently, I had the misfortune to have to write some JavaScript which needed to work in IE6.  Basically, I wanted to create a loading screen for a web page.  Basically the code looks like:...</title>
		<link rel="alternate" type="text/html" href="https://www.theeggeadventure.com/wikimedia/index.php?title=Javascript_callback_recursion&amp;diff=2066&amp;oldid=prev"/>
		<updated>2009-03-23T05:27:35Z</updated>

		<summary type="html">&lt;p&gt;New page: Recently, I had the misfortune to have to write some JavaScript which needed to work in IE6.  Basically, I wanted to create a loading screen for a web page.  Basically the code looks like:...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Recently, I had the misfortune to have to write some JavaScript which needed to work in IE6.  Basically, I wanted to create a loading screen for a web page.  Basically the code looks like:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code lang=&amp;quot;javascript&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;script type=&amp;quot;text/javascript&amp;quot;&amp;gt;&lt;br /&gt;
  var urls = [&lt;br /&gt;
  &amp;quot;../javascript/textutils.js&amp;quot;,&lt;br /&gt;
  &amp;quot;../javascript/x/x.js&amp;quot;,&lt;br /&gt;
  &amp;quot;../javascript/x/x_util.js&amp;quot;,&lt;br /&gt;
  &amp;quot;../javascript/compass.js&amp;quot;,&lt;br /&gt;
  &amp;quot;../javascript/x/xmenu3.js&amp;quot;,&lt;br /&gt;
  &amp;quot;../javascript/Listener.js&amp;quot;,&lt;br /&gt;
  &amp;quot;../javascript/Clipboard.js&amp;quot;,&lt;br /&gt;
  ]&lt;br /&gt;
  function loadResources()&lt;br /&gt;
  {&lt;br /&gt;
    update(currentStep + &amp;#039;/&amp;#039; + progressbar_steps);&lt;br /&gt;
    if(currentStep&amp;lt;progressbar_steps){&lt;br /&gt;
      var url = urls[currentStep];&lt;br /&gt;
      moveProgressBar(1);&lt;br /&gt;
      var req = GetXmlHttpObject();&lt;br /&gt;
      update(&amp;#039;loading &amp;#039; + url);&lt;br /&gt;
      req.open(&amp;quot;GET&amp;quot;, url, true);&lt;br /&gt;
      req.onreadystatechange = getUpdateState(req, url);&lt;br /&gt;
      req.send(null);&lt;br /&gt;
    } else {&lt;br /&gt;
      update(&amp;#039;Done&amp;#039;);&lt;br /&gt;
      window.location = &amp;#039;welcome.htm&amp;#039;;&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  &lt;br /&gt;
  function getUpdateState(req, url) {&lt;br /&gt;
    return function() {&lt;br /&gt;
      var state = req.readyState;&lt;br /&gt;
      if (state != 4) { return; }&lt;br /&gt;
      req = null;&lt;br /&gt;
      setTimeout(&amp;#039;loadResources()&amp;#039;, 0); // This is the magic line to get it to work under IE6!&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  &amp;amp;lt;/script&amp;gt;&amp;amp;lt;/head&amp;gt;&amp;amp;lt;body onload=&amp;quot;javascript: loadResources();&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
LoadResource would register a callback to getUpdateState, which would in turn call LoadResource again until all the resources had been loaded.  Under IE6, a varying number of URLs would get loaded.  Once I added the setTimeout function, it worked fine under IE6.  I guess IE must have just been growing the stack on each callback, and eventually had a stack overflow of some type.  I wouldn&amp;#039;t get a script error when this would happen, rather the loading would just stop.&lt;br /&gt;
&lt;br /&gt;
[[Category:JavaScript]]&lt;br /&gt;
[[Category:Hacks Required to get Javascript to work under IE6]]&lt;/div&gt;</summary>
		<author><name>Egge</name></author>
	</entry>
</feed>