JS加载器如何动态加载外部js文件

时间:2021-05-26

今天在网上找到了一个可以动态加载js文件的js加载器,具体代码如下:

JsLoader.js

var MiniSite=new Object();/*** 判断浏览器*/MiniSite.Browser={ ie:/msie/.test(window.navigator.userAgent.toLowerCase()), moz:/gecko/.test(window.navigator.userAgent.toLowerCase()), opera:/opera/.test(window.navigator.userAgent.toLowerCase()), safari:/safari/.test(window.navigator.userAgent.toLowerCase()) };/*** JsLoader对象用来加载外部的js文件*/MiniSite.JsLoader={/*** 加载外部的js文件* @param sUrl 要加载的js的url地址* @fCallback js加载完成之后的处理函数*/load:function(sUrl,fCallback){ var _script=document.createElement('script'); _script.setAttribute('charset','gbk'); _script.setAttribute('type','text/javascript'); _script.setAttribute('src',sUrl); document.getElementsByTagName('head')[].appendChild(_script); if(MiniSite.Browser.ie){ _script.onreadystatechange=function(){ if(this.readyState=='loaded'||this.readyStaate=='complete'){ //fCallback();if(fCallback!=undefined){fCallback(); }} }; }else if(MiniSite.Browser.moz){ _script.onload=function(){ //fCallback(); if(fCallback!=undefined){fCallback(); }}; }else{ //fCallback();if(fCallback!=undefined){fCallback(); }} } };

JsLoader.js测试

<!DOCTYPE HTML><html><head><!--引入js加载器 --><script type="text/javascript" src="js/JsLoader.js"></script><title>JsLoaderTest.html</title><script type="text/javascript">if(MiniSite.Browser.ie){//动态加载JsMiniSite.JsLoader.load("js/jquery-...js",function(){alert("动态加载的是jquery-...js");$(function(){alert("jquery-...js动态加载完成之后做的处理操作");});}); }else{MiniSite.JsLoader.load("js/jquery-...js",function(){alert("动态加载的是jquery-...js");$(function(){alert("jquery-...js动态加载完成之后做的处理操作");});});}</script></head><body></body></html>

测试结果如下:

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章