为了账号安全,请及时绑定邮箱和手机立即绑定

这里我指定了异步加载async=true,那么我怎么才知道这个脚本是否加载完成呢?

这里我指定了异步加载async=true,那么我怎么才知道这个脚本是否加载完成呢?

GCT1015 2023-04-14 17:13:20
我们在写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);而且http://example.com/static.js里的内容是我完全不能控制的,也就是不能在里面加个回调callback来表示加载完成,大家有什么思路吗?
查看完整描述

2 回答

?
Smart猫小萌

TA贡献1911条经验 获得超7个赞

你可以用script的onload事件判断

js.onload = function() {
    alert("loaded");}


查看完整回答
反对 回复 2023-04-17
?
慕尼黑8549860

TA贡献1818条经验 获得超11个赞

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


查看完整回答
反对 回复 2023-04-17
  • 2 回答
  • 0 关注
  • 79 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信