Stel dat je op een heleboel pagina's een include zou gaan doen, en binnen die include wilde je wat jQuery-specifieke dingen doen. Op die pagina kan jQuery al dan niet al geladen zijn. Als dit al het geval is, wilt u het niet opnieuw laden, maar zo niet, dan wel. Dit werkt daarvoor.
Slimme asynchrone manier
// Only do anything if jQuery isn't defined if (typeof jQuery == 'undefined') ( if (typeof $ == 'function') ( // warning, global var thisPageUsingOtherJSLibrary = true; ) function getScript(url, success) ( var script = document.createElement('script'); script.src = url; var head = document.getElementsByTagName('head')(0), done = false; // Attach handlers for all browsers script.onload = script.onreadystatechange = function() ( if (!done && (!this.readyState || this.readyState == 'loaded' || this.readyState == 'complete')) ( done = true; // callback function provided as param success(); script.onload = script.onreadystatechange = null; head.removeChild(script); ); ); head.appendChild(script); ); getScript('http://ajax.googleapis.com/ajax/libs/jquery/1.4.4/jquery.min.js', function() ( if (typeof jQuery=='undefined') ( // Super failsafe - still somehow failed… ) else ( // jQuery loaded! Make sure to use .noConflict just in case fancyCode(); if (thisPageUsingOtherJSLibrary) ( // Run your jQuery Code ) else ( // Use .noConflict(), then run your jQuery Code ) ) )); ) else ( // jQuery was already loaded // Run your jQuery Code );
Merk op dat er meerdere plaatsen zijn waar de jQuery-code die u wilt uitvoeren, wordt aangeroepen. Herhaal jezelf daar niet, plaats het in een functie die je kunt gebruiken om dingen af te trappen.
Deze code is vanaf hier aangepast.
Document.write manier
Hippe kinderen gebruiken document.write niet, maar als je te oud bent:
var jQueryScriptOutputted = false; function initJQuery() ( //if the jQuery object isn't available if (typeof(jQuery) == 'undefined') ( if (! jQueryScriptOutputted) ( //only output the script once… jQueryScriptOutputted = true; //output the script (load it from google api) document.write(""); ) setTimeout("initJQuery()", 50); ) else ( $(function() ( // do anything that needs to be done on document.ready // don't really need this dom ready thing if used in footer )); ) ) initJQuery();