A while back, I created an AJAX file upload demo using jQuery and ColdFusion. The demo worked quite nicely, but people using FireFox 3 were telling me that FireFox never stopped loading. That is, the page would execute fine, but the window would signal (via the Status Bar and loading circle) that it never completed loading the page. Based on some feedback from Josh, I narrowed the problem down to the removal of the iFrame from the page during its own load callback:
Launch code in new window » Download code as text file »
Something about removing the iFrame as part of the its own load() event binding was causing issues. To get around this, all I had to do was add a slight delay to the actual removal of the iFrame:
Launch code in new window » Download code as text file »
By delaying the iFrame removal for a tenth of a second (could have been smaller), it seems to allow the load() event to execute properly without causing any hanging on the page. FireFox acknowledges that the iFrame has in fact stopped loading once the load() event has finished executing. Then, once it's done executing, we can then safely remove the iFrame from the page.
I am sure that there are a number of scenarios that would cause FireFox to never stop loading, but this is a solution to one of them.
Download Code Snippet ZIP File
Comments (4) | Post Comment | Ask Ben | Permalink | Other Searches | Print Page
My First ColdFusion 8 CFFTP Experience - Rocky But Triumphant
Apple iPhone 3G Has Been Extremely Frustrating
I've gotten to the point in my code where absolutely any removal of a DOM object is done asynchronously. Too many browsers do strange things where you remove an object and it is in any way tied via an event to the code you are currently running.
Yeah, it's paranoia. Yeah, it's cargo cult. But as the example above shows, it's a line or two of code that prevents hours of debugging headaches.
Posted by Rick O on Aug 27, 2008 at 10:41 AM
@Rick,
Better to be paranoid than have to exhaustively test on every browser and version ever made :) I like your style.
Posted by Ben Nadel on Aug 27, 2008 at 11:01 AM
"Based on some feedback from Josh, I narrowed the problem down to the removal of the iFrame from the page during its own load callback"
Doctor, I think this man has Apple Fever. ;)
Posted by Craig on Aug 28, 2008 at 3:19 AM
@Craig,
Ha ha :) Good catch.
Posted by Ben Nadel on Aug 28, 2008 at 8:13 AM