Dynamic loading of javascript files into web pages

N

neilc

Hello I've got the following code

<script type="text/javascript">

var aScripts = [ "scripts/jquery.js", "scripts/jquery.scrollTo-
min.js", "scripts/jquery.localscroll-min.js" ];

function forEach( array, action ) {
for (var i = 0; i < array.length; i++)
action(array);
}

function loader_( array ) {
forEach(array, function (element) {
var p = document.getElementsByTagName( "HEAD" )[0];
var c = document.createElement( "script" );
c.type= "text/javascript";
c.src = element;
p.appendChild( c );
});
}

loader_( aScripts );

</script>

Which I've placed into the <head> element of my html page. The idea is
to speed up the loading of the javascript into the page. Some pages
load in 10 or so other javascript pages and this really helps.

The problem is that it doesnt want to work properly in IE 6 or Safari
4. Neither browser tells me what the problem is but I just wanted to
know if anyone had any suggestions as to where I should be looking
next.

thanks
Neil
 
T

Thomas 'PointedEars' Lahn

neilc said:
Hello I've got the following code

<script type="text/javascript">

var aScripts = [ "scripts/jquery.js", "scripts/jquery.scrollTo-
min.js", "scripts/jquery.localscroll-min.js" ];

My condolences.
function forEach( array, action ) {
for (var i = 0; i < array.length; i++)
action(array);
}


JavaScript 1.7+ (current: 1.8) already as Array.prototype.forEach(), you
should use that where available.
function loader_( array ) {
forEach(array, function (element) {
var p = document.getElementsByTagName( "HEAD" )[0];

Should be lowercase.
var c = document.createElement( "script" );
c.type= "text/javascript";
c.src = element;
p.appendChild( c );
});
}

loader_( aScripts );

</script>

Which I've placed into the <head> element of my html page. The idea is
to speed up the loading of the javascript into the page.

By loading more script code? Think again.
Some pages load in 10 or so other javascript pages and this really helps.

Rubbish.


PointedEars
 
P

Peter Michaux

Hello I've got the following code

<script type="text/javascript">

var aScripts = [ "scripts/jquery.js", "scripts/jquery.scrollTo-
min.js", "scripts/jquery.localscroll-min.js" ];

function forEach( array, action ) {
for (var i = 0; i < array.length; i++)
action(array);
}

function loader_( array ) {
forEach(array, function (element) {
var p = document.getElementsByTagName( "HEAD" )[0];
var c = document.createElement( "script" );
c.type= "text/javascript";
c.src = element;
p.appendChild( c );
});
}

loader_( aScripts );

</script>

Which I've placed into the <head> element of my html page. The idea is
to speed up the loading of the javascript into the page.


The above script shouldn't be speeding up the process of loading
JavaScript files. The same files are still travelling across the wires
from the server to the browser.
Some pages
load in 10 or so other javascript pages and this really helps.

I don't see how it helps. Do you have some definitive tests showing it
does?
The problem is that it doesnt want to work properly in IE 6 or Safari
4. Neither browser tells me what the problem is but I just wanted to
know if anyone had any suggestions as to where I should be looking
next.

You've replaced using straightforward, well supported script tags with
a src attributes by the complex and iffy script above. Even had you
not reported problems, I would suspect some browsers wouldn't react
well to what you are doing.

Peter
 
P

Peter Michaux

neilc said:
Hello I've got the following code
<script type="text/javascript">
           var aScripts = [  "scripts/jquery.js", "scripts/jquery.scrollTo-
min.js", "scripts/jquery.localscroll-min.js" ];

My condolences.
           function forEach( array, action ) {
             for (var i = 0; i < array.length; i++)
               action(array);
           }


JavaScript 1.7+ (current: 1.8) already as Array.prototype.forEach(), you
should use that where available.


I'd say, in this case, if this script has to stay at all, for some
unknown reason to me, then just get rid of forEach as it is bulking up
what is supposed to be a small helper script. Use a for loop in the
loader_ function and avoid the idea of using the native
Array.prototype.forEach all together.

Peter
 
J

Jeremy J Starcher

By loading more script code? Think again.

Although I have not run my own tests, there are a number of timing tests
out there that indicate many browsers will load script elements embedded
in the HTML one at a time, blocking all other IO until the script is
loaded.

Load four scripts, they load one after another while blocking all other
elements on the page from loading at the same time. By making them
dynamically declared script elements (either using document.write or
dynamic SCRIPT elements), it allows concurrent loading with other
elements.

IIRC, The "Why Slow" Or 'yslow' extension for Firefox demonstrates this.
I forget how they tested the other browsers.
 
P

Peter Michaux

Load four scripts, they load one after another while blocking all other
elements on the page from loading at the same time.  By making them
dynamically declared script elements (either using document.write or
dynamic SCRIPT elements), it allows concurrent loading with other
elements.

I wish Randy Webb was around right now. I've cc'ed him on this
message. He is/was a fan of dynamic script tag insertion at least for
some purposes.

Peter
 
T

Thomas 'PointedEars' Lahn

Jeremy said:
Although I have not run my own tests, there are a number of timing tests
out there that indicate many browsers will load script elements embedded
in the HTML one at a time, blocking all other IO until the script is
loaded.

Works as designed.
Load four scripts, they load one after another while blocking all other
elements on the page from loading at the same time. By making them
dynamically declared script elements (either using document.write or
dynamic SCRIPT elements), it allows concurrent loading with other
elements.

And risking runtime errors because required methods and properties are
not yet there, if ever? No, thanks. But wait -- these tests have been
performed by people who are clueless enough to advocate "Unobtrusive
JavaScript" and huge abominations like jQuery, yes?

10 scripts in one document ... o tempora, o mores.


PointedEars
 
N

neilc

Hello I've got the following code
<script type="text/javascript">
                var aScripts = [  "scripts/jquery.js", "scripts/jquery.scrollTo-
min.js", "scripts/jquery.localscroll-min.js" ];
                function forEach( array, action ) {
                  for (var i = 0; i < array.length;i++)
                    action(array);
                }

                function loader_( array ) {
                  forEach(array, function (element) {
                        var p = document.getElementsByTagName( "HEAD" )[0];
                                var c = document.createElement( "script" );
                                c.type= "text/javascript";
                                c.src = element;
                                p.appendChild( c );
                  });
                }
                loader_( aScripts );

Which I've placed into the <head> element of my html page. The idea is
to speed up the loading of the javascript into the page.

The above script shouldn't be speeding up the process of loading
JavaScript files. The same files are still travelling across the wires
from the server to the browser.
Some pages
load in 10 or so other javascript pages and this really helps.

I don't see how it helps. Do you have some definitive tests showing it
does?
The problem is that it doesnt want to work properly in IE 6 or Safari
4. Neither browser tells me what the problem is but I just wanted to
know if anyone had any suggestions as to where I should be looking
next.

You've replaced using straightforward, well supported script tags with
a src attributes by the complex and iffy script above. Even had you
not reported problems, I would suspect some browsers wouldn't react
well to what you are doing.

Peter


Thanks for all the replies, I've created some passionate feelings
here !

Some of you totally missed the point with this and obviously
understand how the web browsers works.

But thanks to Jeremy J Starcher for getting what I meant.
Although I have not run my own tests, there are a number of timing tests
out there that indicate many browsers will load script elements embedded
in the HTML one at a time, blocking all other IO until the script is
loaded.

This is exactly what happens and this is an attempt to load all
scripts at the same time. If you use firebug and look at the .net tab
you will see how this works.

My tests show that I've consistently saved 1 second by implementing
this method (in firefox and ie7) but as I mentioned ie6 and safari 4
seem barf.

There is a discussion here

http://stackoverflow.com/questions/...cally-load-a-javascript-file-think-cs-include
and
http://www.artzstudio.com/2008/07/beating-blocking-javascript-asynchronous-js/

For those who do not get it (ie PointedEars)
 
T

Thomas 'PointedEars' Lahn

neilc said:

How typical, script-kiddie. You need to refer to work of
other people because you don't have any arguments yourself.
For those who do not get it (ie PointedEars)

*You* don't get it. If you continue loading the document while scripts are
loading (if that, all of this is based on the weak assumption that scripts
can be dynamically loaded everywhere), methods that these scripts provide
may or may not be available while the document is loading.

That is not a problem if you follow the ill-advised "Unobtrusive JavaScript"
approach to the letter because then there is no script code in the `body'
element. However, if you follow the standards-compliant and reliable
approach which includes event delegation, event listeners that call methods
that do not yet exist (because the scripts that define them have not been
loaded or not fully loaded yet) cause runtime errors. And because the
scripts may not be loaded in sequential order, if at all, and features of
the scripts are likely not be used in sequential order in the document, it
will work on one element and fail on another. So much for user experience.

Then again, when it has become necessary to load scripts dynamically in
order to create a viable document, maybe, just maybe, there is something
wrong with the scripts, such as size (for including a lot of unused
features, or providing them through unnecessarily extensive method
overloading), or runtime efficiency (for thinking every computer is under
all conditions as fast as the testing system, and for foolishly thinking it
would be faster to add a listener to every element in sight instead of event
delegation)?

And when there are 10 scripts or more in a document, maybe, just maybe,
somebody has not understood a first thing about browser scripting and Web
authoring, and just tries to have their tag soup spiced by including a dozen
script libraries from everywhere, written by equally clueless people?


PointedEars
 
N

neilc

Thanks for you response, this is a much better explanation than your
previous efforts which were rude and unhelpful. I appreciate you
taking the time to explain. You're tone is a quite uptight and
childish, you might enjoy life more if you had some therapy ? Being
nice to people is much more rewarding. You should try it.

From what you've suggested perhaps the best thing to do is try and put
all the scripts in one file perhaps and minify this, rather than the
approach I've taken. Then I could just use a standard include method.

I agree that the scripts/libraries I'm including could have some
excess baggage, but I don't have the time to go through and trim them
so I'm looking at other methods to speed up page loading. Don't get me
wrong - my pages are quite fast anyway and dont provide a problem -
but I'm just looking at ways of trimming a few milliseconds off them.
 
J

Jorge


And a video here: Steve Souders: "Life's Too Short - Write Fast Code
(part 2)", "Advanced script loading: six ways to load scripts without
blocking the page" (starting @10m40s)

DON'T MISS IT: John Resig's über-cool "degrading script pattern",
starting @22m15s.

I wonder why jewels like these don't make its way into the resources
FAQ.
 
T

Thomas 'PointedEars' Lahn

Thomas said:
How typical, script-kiddie. You need to refer to work of
other people because you don't have any arguments yourself.

And, of course, you have selective perception, too:

,-<http://stackoverflow.com/questions/...cally-load-a-javascript-file-think-cs-include>
|
| I used a much less complicated version recently with jQuery:

jQuery, hm, hm. What was the reason he used jQuery despite considerable
criticism? Cult-like dependency because of cluelessness? I see.

| It worked great in every browser I tested it in: IE6/7, Firefox, Safari,
| Opera.

Extraordinary. Now you need to test all the other browsers out there, dude,
and hope nothing changes about this undocumented feature in the future.

| The technique we use at work is to request the javascript file using an
| AJAX request and then eval() the return. If you're using the prototype
| library, they support this functionality in their Ajax.Request call.

"AJAX request", hm, hm. What if "AJAX" is not supported or disabled?
You don't care for those users? I see.

| i've used yet another solution i found on the net ... this one is under
| creativecommons and it checks if the source was included prior to calling
| the function ...
|
| /** include - including .js files from JS - (e-mail address removed) - 2005-02-09
| ** Code licensed under Creative Commons Attribution-ShareAlike License
| ** http://creativecommons.org/licenses/by-sa/2.0/
| **/
| var hIncludes = null;
| function include(sURI)
| {
| if (document.getElementsByTagName)
| {
| if (!hIncludes)
| {
| hIncludes = {};
| var cScripts = document.getElementsByTagName("script");
| for (var i=0,len=cScripts.length; i < len; i++)
| if (cScripts.src) hIncludes[cScripts.src] = true;
| }
| if (!hIncludes[sURI])
| {
| var oNew = document.createElement("script");
| oNew.type = "text/javascript";
| oNew.src = sURI;
| hIncludes[sURI]=true;
| document.getElementsByTagName("head")[0].appendChild(oNew);
| }
| }
| }

Ridiculous. Not only that it doesn't do as advertised (anybody surprised?),
the whole point of asynchronous loading is that execution continues while
the script is loading. Therefore, the existence of the `script' element
(which is not even tested here!) does not mean anything for the loading
state of the script.

(What might work for detection is declaring a variable at the top of the
script and assigning an identifying value to it at the bottom. We have
discussed this before.)

| Just found out about a great feature in YUI 3 (at the time of writing
| available in preview release). You can easily insert dependencies to
| YUI libraries and to "external" modules (what you are looking for)
| without too much code: YUI Loader.

Which follows the same weak assumption, of course. But then YUI is not
designed to degrade gracefully, to follow accessibility guidelines and
legislation and all.

| all the major javascript libraries like jscript, prototype, YUI have
| support for loading script files.

Let's eat sh*t! A million flies can't be wrong.

,-<|
| You've replaced using straightforward, well supported script tags with
| a src attributes by the complex and iffy script above. Even had you
| not reported problems, I would suspect some browsers wouldn't react
| well to what you are doing.

Finally, hear the voice of reason.

,-<http://www.artzstudio.com/2008/07/beating-blocking-javascript-asynchronous-js/>
|
| 5. Vladimir Dzhuvinov tipped... September 15th, 2008 at 1:07 am
|
| Hi,
|
| I don’t know how versed your readership is, but in case there are any
| casual readers, it would be good first to explain to them that browser
| interpreters “block†script execution for a good reason:
|
| http://www.mozilla.org/js/language/js20-1999-03-25/execution-model.html
|
| 6. Arup stated... October 7th, 2008 at 4:06 am
|
| This implementation has several disavantages also . Like page timeout
| functionality . Sometimes the ojects are set to null and js not works
| on the page .

Even some people there got it.
For those who do not get it (ie PointedEars)

*You* don't get it. If you continue loading the document while scripts are
loading (if that, all of this is based on the weak assumption that scripts
can be dynamically loaded everywhere), methods that these scripts provide
may or may not be available while the document is loading.
[...]
Then again, when it has become necessary to load scripts dynamically in
order to create a viable document, maybe, just maybe, there is something
wrong with the scripts, such as size (for including a lot of unused
features, or providing them through unnecessarily extensive method
overloading), or runtime efficiency (for thinking every computer is under
all conditions as fast as the testing system, and for foolishly thinking it
would be faster to add a listener to every element in sight instead of event
delegation)?

And when there are 10 scripts or more in a document, maybe, just maybe,
somebody has not understood a first thing about browser scripting and Web
authoring, and just tries to have their tag soup spiced by including a dozen
script libraries from everywhere, written by equally clueless people?

q.e.d.

BTW, check out loadScript() from <http://PointedEars.de/dhtml.js>, and
notice the copyright date in the JSdoc ...


PointedEars
 
T

Thomas 'PointedEars' Lahn

neilc said:
Thanks for you response, this is a much better explanation than your
previous efforts which were rude and unhelpful. I appreciate you
taking the time to explain. You're tone is a quite uptight and
childish, you might enjoy life more if you had some therapy ?

*PLONK*
 
O

One Dumm Hikk

I wish Randy Webb was around right now. I've cc'ed him on this
message. He is/was a fan ofdynamicscript tag insertion at least for
some purposes.

Peter

You found me. I have no idea why but AOL put the email in my
spam folder and for the first time in almost 2 months I looked
through it. I guess fate had it that I should see it.

Dynamically loading script files to speed up the loading process?
Garbage.

What it will do, if done properly, is speed up the initial
rendering of the page. But it WON'T speed up load time of the
files and will actually slow it down. The reason it will
actually slow it down is because it has to do more work to
load the files. Whether the file is static coded or dynamically
loaded, the file still has to be downloaded from the server.
Want it to download faster? Make the file physically smaller.
Any other advice is magical hocus-pocus for making it load
faster if everything else is the same.

As for the script posted, it won't speed up page rendering
even if you get it to work. Why? It isn't loading the scripts
after the onload event fires, it is trying to dynamically
load them AS the page is loading. No difference than having
them hard coded in script tags.

Aside from some of the problems pointed out already, there
remains an issue of the way you are calling it. Rather than
calling it inline as you are, assign it to the onload event
handler so that the scripts aren't loaded until the onload
event fires. When the onload event fires, the page will render.

function loader() {
var aScripts = [ "scripts/jquery.js",
"scripts/jquery.scrollTomin.js",
"scripts/jquery.localscrollmin.js" ];

for (var i = 0; i < aScripts.length; i++)
{
var p = document.getElementsByTagName( "HEAD" )[0];
var c = document.createElement( "script" );
c.type= "text/javascript";
c.src = aScripts;
p.appendChild( c );
}
}
window.onload = loader;

Then, it won't try to load them until the page has loaded
and that will APPEAR to speed up the page loading but it won't.
It will actually slow down total page load time.

Ever wonder why people think JS is so hard? Because they try to
make it harder than it has to be. KISS - Keep It Simple Stupid.

After all this time, I would have thought TL had exited certain
stages of life but I see he hasn't. Sad.
 
G

Garrett Smith

Jorge said:
And a video here: Steve Souders: "Life's Too Short - Write Fast Code
(part 2)", "Advanced script loading: six ways to load scripts without
blocking the page" (starting @10m40s)

DON'T MISS IT: John Resig's über-cool "degrading script pattern",
starting @22m15s.

Thanks for that link. That is horrible advice and should be avoided.

It was discussed on John Resig's website[0].
I wonder why jewels like these don't make its way into the resources
FAQ.

Good point. It is worth mentioning that there is a lot of poor advice
provided by experts that should not be followed. The web is horribly
broken. This video serves as an excellent example of an "industry
expert" providing up horrible advice. It should be recommended against
and the section on "John Resig's degrading script tags", which Steve
calls "really really awesome", serves as a fine example of why.

<FAQENTRY>
Q: I saw a video online. Why wasn't it in the FAQ?
A: Video presentations often contain advice that is either
incorrect or inadvisable. It possible, though unlikely, that the video
has not been reviewed and contains accurate and valuable information.
Before posting a request for review, please search the archives for
discussion about the video.
</FAQENTRY>

Steve:
| It turns out, this is really really awesome, but it actually doesn't
| work in any browser. There's no browser that works this way to like
| pay attention to the code in the script blocks if there's a source
| attribute being used.
|
| But it turns out its really easy across all browsers to add that.
| And the way we add that is.. Oh, and this is nice because it's
| cleaner, there's only one script tag instead of two script blocks,
| it's clearer, its very clear that this script code has a dependency
| on menu.js, um, and it's safer. If the external script fails, then,
| ah, the inline code won't be scalled.
|
| But, since it doesn't work in any browser, you have to do a little
| work. And it's not that much work and it's not that complicated, so
| at the end of menu.js, so that's why I renamed it to
| "menu-degrading.js", so at the end of "menu-degrading.js", I basically
| just do this loop:
|
| I get all the script elements, I loop through them, until I find the
| script whose name is "menu jay", "menu-degrading.js" and then I look
| at its innerHMTL property. And that's basically going to be, innerHTML
| is going to be this code, right here (points to example), and I just
| eval it.

None of the three reasons is true. All are blatantly false and in being
false, they serve as reasons for eschewing this technique.

Because a SCRIPT element is not allowed to have HTML, expecting a script
tag to have its text available as innerHTML seems risky. For example:

javascript: alert( document.createElement("script").canHaveHTML)

The "inline code" here is defined as fallback content in HTML 4.01[1].
That means it is only displayed if the script does *not* load. That is
the exact opposite of what this technique requires. Here, Steve is
expecting the fallback content of a script tag to be executed only when
the src is loaded. This works exactly the opposite of the way the HTML
4.01 standard states and this was clearly pointed out on John Resig's
blog[3][4]. It is unreasonable for Steve to have ignored this criticism,
yet he continued to advocate it *after* that fact was pointed out. Steve
Souders is arrogant and not amenable to criticism.

The script's innerHTML is then passed to eval.

The file name changed it's not "menu.js", but now "menu-degrading.js",
but notice how Steve gets that wrong a couple of times. That right there
is evidence that the "degrading" part is unrelated to the original code.

The inline code at the end of menu-degrading.js loops through elements
in the document. It uses all global variables, including a global loop
counter |i|. The eval method is called in global context.

Looping through the DOM while the page loads is a strategy that hurts
performance.

AISB, eval is called in global context. Steve did not mention this, and
the code is so naive that I doubt he is even aware of it, but the code
must exist in global context, or use a separate sandbox function. This
has to do with eval using the scope of the calling context, variable
object, and the this value. If eval is called within a function, then it
will use that function's [[Scope]], variable object, and |this| value.
This can complicate the situation by identifiers being resolved to that
scope chain.

Example:
function doEval(s) {
var i = 10;
eval(s);
alert(i);
}

doEval("i = 20;");

Result:
elerts "20";

I've used the identifier |i| on purpose because it is a common mistake
to forget |var| in initializing a loop variable.

Such issue might not happen on a simple first test. However, if put into
production, it could happen at a later time with different data and
different identifiers. It could potentially causing bugs that might not
arise immediately. If and when they happen in production, it would
severly compromise the security of an application. Inline code often
makes use variables from the server, e.g.:- <%= serverOutput %>, so it
might be a problem that could go unnoticed until, well, it became a
horrible security problem.

Steve mentions in that video that "Doug" remained silent when he
mentioned eval.

Another problem with eval is that when an EvalError occurs, the browser
may not provide information about what was being eval'd that caused the
problem. Instead, the browser will state that eval(s) caused a problem.
Since eval can't be stepped into, it is harder to debug. Indeed, this
is a problem in Dojo that I noticed way back in Dojo 0.4.

Back to Steve's example, that the file "menuteir.js" now has to know
something about the application's performance tricks. That is awful
design and a flagrant violation of SRP. Steve says it is cleaner and
clearer. That is untrue. It is less clear, more complicated because it
requires more code inside menuteir.js to execute the inline script
content. The menuteir.js should not be have knowledge of the performance
tricks used to include it. It severely complicates things; it does not
make things simpler, nor clearer.

It does not make things "safer" either, as I have already explained the
problems with eval.

| If the external script fails, then the inline code won't be called.

That may be true in buggy implementations, but according to the HTML
4.01 specification, the exact opposite is designed to happen. Code
should not rely on specification violations. Utilizing proprietary
(MSIE) extensions is one thing, but expecting every browser to go
against the spec is a very *unsafe* design decision.

Not cleaner, nor clearer, nor safer.

The technique requires implementations to violate the HTML 4 standard.
(According to Steve, this is "all browsers"). It complicates the design
of the code, making it harder to tune and increase likelihood of errors.
For browsers that behave the way Steve wants, Steve's approach impacts
performance by looping through the DOM, and, by using eval, introduces
fragility into the code by eval.

It is really a very poor idea. As Randy said, KISS.

Steve Souders is ignoring valid criticism, disregarding public
standards, and throwing caution to the wind.

I see that Randy and Thomas have their own thoughts on this. The
criticism I provide can tends to annoy the "experts" quite a bit. See
the whatwg list for details. Good to see that I am not alone here.

The part about "depends" in 28:00 is where steve talks about declarative
chaining of script loads. It is another very poor design idea, and it
prompted my proposal for "depends" on script tags on whatwg. That design
idea follows the "I'm Done" paradigm, not "Do This". For more
information on "I'm Done", see H.S. Lahman's explanations on comp.object.

The "Managed XHR" solution also requires eval, and has all the
complications associated with that, just as in Dojo.

Technique 4 Script onload aka "The Best One", shows code that modifies
Host objects with expandos. For reasons that have been discussed here
many times, code which modifies host objects is error prone. According
to Steve, if you use both onload and onreadystatechange, it will work in
"all browsers". Again, this relies on the approach of "Do This" instead
of "I'm Done".

I do agree that this deserves mention in the FAQ. If Steve's book is
going to be included, it ought to mention that his application design
advice is considerably harmful.

Garrett
[0]http://ejohn.org/blog/degrading-script-tags#postcomment
[1]http://www.w3.org/TR/html401/interact/scripts.html#h-18.2.1
[3]http://ejohn.org/blog/degrading-script-tags#comment-319983
[4]http://ejohn.org/blog/degrading-script-tags#comment-320005
 
G

Gregor Kofler

One Dumm Hikk meinte:
Ever wonder why people think JS is so hard? Because they try to
make it harder than it has to be. KISS - Keep It Simple Stupid.

But then John Resig and his colleagues couldn't fill their blogs with
sparkling new ideas of how to "optimize" code.

As Jorge already mentioned:
and the "degrading script
pattern" - it escapes me where the actual problem is, requesting such a
bizarre "solution".

Gregor
 
J

Jorge

(...)
As Jorge already mentioned:
the "degrading script
pattern" - it escapes me where the actual problem is, requesting such a
bizarre "solution".

The problem is:

- Given a script that has not been loaded yet (still loading), -
usually a dynamically inserted one-,
- Find the best way to have some piece of code run asap, immediatly
after the script (above) has loaded and executed.

(note that "onload" is not -usually- available on <script> tags in
most browsers)

I think that Resig's idea is great for many reasons. Unless, or until,
somebody else shows me a better way...
 
J

Jorge

(...)
I do agree that this deserves mention in the FAQ. If Steve's book is
going to be included, it ought to mention that his application design
advice is considerably harmful.

Mention that *you* consider it harmful.
 
J

Jorge

Dynamically loading script files to speed up the loading process?
Garbage.

What it will do, if done properly, is speed up the initial
rendering of the page. But it WON'T speed up load time of the
files and will actually slow it down. The reason it will
actually slow it down is because it has to do more work to
load the files. Whether the file is static coded or dynamically
loaded, the file still has to be downloaded from the server.
Want it to download faster? Make the file physically smaller.
Any other advice is magical hocus-pocus for making it load
faster if everything else is the same.
(...)


I'm not sure why do you say so, as it's obvious (isn't it ?) that
latency times add up when the scripts are loaded in series.

And for servers that throttle downloads (more and more each day, e.g.
youtube, me.com...), the time to download n scripts in parallel is not
necessarily === n* the time to download a single one.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
473,981
Messages
2,570,188
Members
46,731
Latest member
MarcyGipso

Latest Threads

Top