IE9 - SCRIPT5009:“jQuery”未定义

时间:2013-04-07 14:34:25

标签: javascript jquery internet-explorer cross-browser

以下代码遇到错误 SCRIPT5009:" jQuery"在IE9中未定义(也许在较旧的IE版本中):

var $tx;
if (window.jQuery) {
    $tx = jQuery;
    if( jQuery().jquery.replace(".", "") < 17.1 ) {
        addjQuery();
    }   
} else {
    addjQuery();
}
function addjQuery() {
    document.write('<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"><\/script>');
    document.write('<script type="text/javascript">$tx = jQuery.noConflict();<\/script>');
}
document.write('<script src="workingScript.js"><\/script>');

我解决了!它以这种方式正常工作:

var $tx;
if (window.jQuery) {
    $tx = jQuery;
    if( jQuery().jquery.replace(".", "") < 17.1 ) {
        addjQuery();
    }   
} else {
    addjQuery();
}
function addjQuery() {
    loadScript("http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js", function(){
        $tx = jQuery.noConflict(true);
    });
}
document.write('<script src="workingScript.js"><\/script>');

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);
}

workingScript.js:

(function ($) {
    // some code here
})($tx);

此处出现错误&#34; $ tx = jQuery.noConflict();&#34; 如果调用了addjQuery函数。如果网站已经使用了当前的jQuery版本,那么错误的工作正常。

有没有人知道如何解决这个问题?

1 个答案:

答案 0 :(得分:3)

您的脚本在执行期间加载其他脚本,它们不会同步执行,而是异步执行。当$tx = jQuery.noConflict();执行时,无法保证jQuery已加载。

如果您需要同步see this question,或者更好地使用RequireJS之类的东西来处理这个问题。 (它也允许这种后退)。