判断javascript加载完成的方法

function include_js(file) {
    var _doc = document.getElementsByTagName('head')[0];
    var js = document.createElement('script');
    js.setAttribute('type', 'text/javascript');
    js.setAttribute('src', file);
    _doc.appendChild(js);
 
    if (!/*@cc_on!@*/0) { //if not IE
        //Firefox2、Firefox3、Safari3.1+、Opera9.6+ support js.onload
        js.onload = function () {
            alert('Firefox2、Firefox3、Safari3.1+、Opera9.6+ support js.onload');
        }
    } else {
        //IE6、IE7 support js.onreadystatechange
        js.onreadystatechange = function () {
            if (js.readyState == 'loaded' || js.readyState == 'complete') {
                alert('IE6、IE7 support js.onreadystatechange');
            }
        }
    }
 
    return false;
}

ie 上支持 onreadystatechange , 不支持 onload

firefox上支持 onload , 不支持onreadystatechange

所以jquery里面的解决方案如下

 var done = false;

 script.onload = script.onreadystatechange = function() {

     if(!done && (!this.readyState  || this.readyState == 'loaded' || this.readyState == 'complete')) {

            done = true;   

            callback();

     }

 };

其中 ff onload上面没有readyState 这个值,所以用了 !this.readyState

ie上面不一定loaded 或者是 complete触发 , 或者两个都会触发,所以用一个变量进行了标记。

这样就兼容了浏览器上插入script标签的问题。

posted @ 2011-06-28 11:52  s80895304  阅读(313)  评论(0编辑  收藏  举报