I’ve come to the conclusion that there’s just one best practice for loading JavaScript without blocking:
1. Create two JavaScript files. The first contains just the code necessary to load JavaScript dynamically, the second contains everything else that’s necessary for the initial level of interactivity on the page.
2. Include the first JavaScript file with a tag at the bottom of the page, just inside.
3. Create a second tag that calls the function to load the second JavaScript file and contains any additional initialization code.
A helper to make this happen could look like:
function loadScript(url, callback){
var script = document.createElement("script")
script.type = "text/javascript";
if (script.readyState){ //IE
script.onreadystatechange = function(){
if (script.readyState == "loaded"
script.readyState == "complete"){
script.onreadystatechange = null;
callback();
}
};
} else { //Others
script.onload = function(){
callback();
};
}
script.src = url;
document.getElementsByTagName("head")[0].appendChild(script);
}
In related news, the LABjs folk have updated their API from this:
$LAB
.script("jquery.js")
.block(function(){
$LAB
.script("jquery.ui.js")
.script("myplugin.jquery.js")
.block(function(){
$LAB.script("initpage.js");
});
});
To the simpler:
$LAB
.script("jquery.js")
.block()
.script("jquery.ui.js")
.script("myplugin.jquery.js")
.block()
.script("initpage.js");
I seem to remember that Steve had some opinions on this API too :)
If you have better solution, just tell me !
 
0 comments:
Post a Comment