javascript脚本动态加载时如何检测加载完成
怪我咯
怪我咯 2017-04-10 12:42:46
[JavaScript讨论组]

我们在写js的时候经常要动态加载一段js脚本,比如下面这种代码

var js = document.createElement('script');
js.type = 'text/javascript';
js.async = true;
js.src = 'http://example.com/static.js';
var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(js, s);

这里我指定了异步加载async=true,那么我怎么才知道这个脚本是否加载完成呢?而且http://example.com/static.js里的内容是我完全不能控制的,也就是不能在里面加个回调callback来表示加载完成,大家有什么思路吗?

怪我咯
怪我咯

走同样的路,发现不同的人生

全部回复(2)
天蓬老师

你可以用script的onload事件判断

js.onload = function() {
    alert("loaded");
}
ringa_lee
function Script(callback){
        var js = document.createElement("script");
        this.js = js;
        js.setAttribute("type",'text/javascript');
        var head = document.getElementsByTagName('head')[0];
        head.appendChild(js);
        if(navigator.appName.toLowerCase().indexOf('netscape') == -1){
            js.onreadystatechange = function(){
                if(js.readyState == 'complete'){
                    callback(js);
                }
            }
        }else{
            js.onload = function(){
                callback(js);
            }
        }
    }
    Script.prototype.get = function(url){
        this.js.src = url;
    }
    function script_onload(script){
        alert(script.src);
    }
    var load_js = new Script(script_onload);
    load_js.get('http://static.gongju.com/js/jquery-1.4.4.min.js');
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号