视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
重点解答动态加载JS脚本,一语道破
2020-11-27 19:48:55 责编:小采
文档


用ajax开发网站,用ajax的时候,需要用到大量的JS代码,而并是所有的代码都是要第一个载入的页面要用到,

所以很多的JS代码动态载入比较合适,下面介绍了四种方法,在ajax开发中,第一种方法不合适,2,3,4方法,

本质上是一张方法,详细地的动态加载JS方法如下:
1、直接document.write

<scrīpt language="javascrīpt"> 
 document.write("<scrīpt src='test.js'><//scrīpt>"); 
</scrīpt>

2、动态改变已有scrīpt的src属性

<scrīpt src='' id="s1"></scrīpt> 
<scrīpt language="javascrīpt"> 
 s1.src="test.js" 
</scrīpt>

3、动态创建scrīpt元素

<scrīpt> 
 var oHead = document.
getElementsByTagName
('HEAD').item(0); 
 var oscrīpt= document.createElement("scrīpt"); 
 oscrīpt.type = "text/javascrīpt"; 
 oscrīpt.src="test.js"; 
 oHead.appendChild( oscrīpt); 
</scrīpt>

  这三种方法都是异步执行的,也就是说,在加载这些脚本的同时,主页面的脚本继续运行,如果用以上的方法,那下面的代码将得不到预期的效果。

要动态加载的JS脚本:a.js,以下是该文件的内容。

var str = "中国"; 
alert( "这是a.js中的变量:" + str );

主页面代码:

<scrīpt language="Javascrīpt"> 
function LoadJS( id, fileUrl ) 
{ 
 var scrīptTag = document.getElementById( id ); 
 var oHead = document.getElementsByTagName('HEAD').item(0); 
 var oscrīpt= document.createElement("scrīpt"); 
 if ( scrīptTag ) oHead.removeChild( scrīptTag ); 
 oscrīpt.id = id; 
 oscrīpt.type = "text/javascrīpt"; 
 oscrīpt.src=fileUrl ; 
 oHead.appendChild( oscrīpt); 
} 
LoadJS( "a.js" ); 
alert( "主页面动态加载a.js并取其中的变量:" + str ); 
</scrīpt>

上述代码执行后 a.js 的 alert 执行并弹出消息,

但是 主页面产生了错误,没有弹出对话框。原因是 'str' 未定义,为什么呢?因为主页面在取 str 的

时候 a.js 并没有完全加载成功。遇到需要同步执行脚本的时候,可以用下面的第四种方法。

4、原理:用XMLHTTP取得要脚本的内容,再创建 scrīpt 对象。
注意:a.js必须用UTF8编码保存,要不会出错。因为服务器与XML使用UTF8编码传送数据。
主页面代码:

<scrīpt language="Javascrīpt"> 
function GetHttpRequest() 
{ 
 if ( window.XMLHttpRequest ) // Gecko 
 
return
 new XMLHttpRequest() ; 
 else if ( window.ActiveX
Object
 ) // IE 
 return new ActiveXObject("MsXml2.XmlHttp") ; 
} 
function AjaxPage(sId, url){ 
 var oXmlHttp = GetHttpRequest() ; 
 oXmlHttp.OnReadyStateChange = function() 
 { 
 if ( oXmlHttp.readyState == 4 ) 
 {
 if ( oXmlHttp.status == 200 || oXmlHttp.status == 304 ) 
 {
 
Include
JS( sId, url, oXmlHttp.responseText );
 } 
 else 
 { 
 alert( 'XML request error: ' + oXmlHttp.statusText + ' (' + oXmlHttp.status + ')' ) ; 
 } 
 } 
 } 
 oXmlHttp.open('GET', url, true); 
 oXmlHttp.send(null); 
} 
function IncludeJS(sId, fileUrl, source) 
{ 
 if ( ( source != null ) && ( !document.getElementById( sId ) ) ){ 
 var oHead = document.getElementsByTagName('HEAD').item(0); 
 var oscrīpt = document.createElement( "scrīpt" ); 
 oscrīpt.language = "javascrīpt"; 
 oscrīpt.type = "text/javascrīpt"; 
 oscrīpt.id = sId; 
 oscrīpt.defer = true; 
 oscrīpt.text = source; 
 oHead.appendChild( oscrīpt ); 
 } 
} 
AjaxPage( "scrA", "b.js" ); 
alert( "主页面动态加载JS脚本。"); 
alert( "主页面动态加载a.js并取其中的变量:" + str ); 
</scrīpt>

用ajax同步加载JS代码,加载一个还好,两三个或者更多的时候,还是用异步加载比较快。

我使用第三种方法,每个JS我都为其命名,当某个JS加载完成后,则置一个代表其已经加载完成的标志。

//所有的JS文件 
var jsM = { 
 page : false , 
 dhtmlXTree : false , 
 photo_tree : false 
 }; 
function getJSM(f) 
{ 
 var reg = ///(/w+)/./; 
 jF = f.match(reg); 
 return jF[jF.length-1]; 
} 
function loadJS(js) 
{ 
 id = getJSM(js); 
 var scrīptId = document.getElementById(id); 
 var head = document.getElementsByTagName('head').item(0); 
 if(scrīptId) 
 { 
 //head.removeChild(id); 
 } 
 else 
 { 
 scrīpt = document.createElement('scrīpt'); 
 scrīpt.src = js; 
 scrīpt.type = 'text/javascrīpt'; 
 scrīpt.id = id; 
 head.appendChild(scrīpt); 
 } 
} 
//JS时候,判断jsM中,代表其模块的标识是否为true,如果为false,则尚未加载 
loadJS("page.js") 
[js] view plain copy
//所有的JS文件 
var jsM = { 
page : false , 
dhtmlXTree : false , 
photo_tree : false 
}; 
function getJSM(f) 
{ 
var reg = ///(/w+)/./; 
jF = f.match(reg); 
return jF[jF.length-1]; 
} 
function loadJS(js) 
{ 
id = getJSM(js); 
var scrīptId = document.getElementById(id); 
var head = document.getElementsByTagName('head').item(0); 
if(scrīptId) 
{ 
//head.removeChild(id); 
} 
else 
{ 
scrīpt = document.createElement('scrīpt'); 
scrīpt.src = js; 
scrīpt.type = 'text/javascrīpt'; 
scrīpt.id = id; 
head.appendChild(scrīpt); 
} 
} 
//JS时候,判断jsM中,代表其模块的标识是否为true,如果为false,则尚未加载 
loadJS("page.js")

上面是我整理给大家的动态加载JS脚本,希望今后会对大家有帮助。

相关文章:

javascript中遍历EL表达式List集合中的值

如何在<script></script>标签中一样可以使用el表达式

重写与多态的要点分析解答

下载本文
显示全文
专题