以下代码遇到错误 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版本,那么错误的工作正常。
有没有人知道如何解决这个问题?
答案 0 :(得分:3)
您的脚本在执行期间加载其他脚本,它们不会同步执行,而是异步执行。当$tx = jQuery.noConflict();
执行时,无法保证jQuery已加载。
如果您需要同步see this question,或者更好地使用RequireJS之类的东西来处理这个问题。 (它也允许这种后退)。