首頁 >web前端 >js教程 >JS動態插入並立即執行回呼函數的方法_javascript技巧

JS動態插入並立即執行回呼函數的方法_javascript技巧

WBOY
WBOY原創
2016-05-16 15:04:331630瀏覽

本文實例講述了JS動態插入並立即執行回調函數的方法。分享給大家參考,具體如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<body>
<div id="loading">加载中……</div>
<mce:script type="text/JavaScript">
<!--
function loadJs(id,url,callback){
 var script = document.createElement('script');
 script.type = 'text/javascript';
 script.src = url;
 script.id = id;
 script.onload = script.onreadystatechange = function(){
  alert(script.readyState);
  if(script.readyState && script.readyState != 'loaded' && script.readyState != 'complete') return ;
  script.onreadystatechange = script.onload = null
  if(callback) callback();
 }
 document.body.appendChild(script);
}
loadJs('jQuery','jquery.js',function(){$('#loading').html('jquery.js加载完毕')})
// --></mce:script>
</body>
</html>

動態插入js檔案在提高頁面載入速度和跨域問題上有非常重要的作用。上面就是一個簡單例子。

ie 上支援 onreadystatechange , 不支援 onload

firefox上支援 onload , 不支援onreadystatechange

ie上面不一定loaded 或是 complete觸發 , 或兩個都會觸發,所以用或來判斷。

要注意的是script.onreadystatechange 和script.readyState 的大小寫形式,不區分大小寫就可能導致不易發現的錯誤。

更多關於JavaScript相關內容有興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結》、《JavaScript查找演算法技巧總結》、《JavaScript動畫特效與技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript資料結構與演算法技巧總結》、《JavaScript遍歷演算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程式設計有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn