溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JS怎么實(shí)現(xiàn)動(dòng)態(tài)插入并立即執(zhí)行回調(diào)函數(shù)

發(fā)布時(shí)間:2022-10-22 11:29:55 來源:億速云 閱讀:105 作者:iii 欄目:編程語言

這篇文章主要講解了“JS怎么實(shí)現(xiàn)動(dòng)態(tài)插入并立即執(zhí)行回調(diào)函數(shù)”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“JS怎么實(shí)現(xiàn)動(dòng)態(tài)插入并立即執(zhí)行回調(diào)函數(shù)”吧!

具體代碼如下:

<!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>無標(biāo)題文檔</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>

動(dòng)態(tài)插入js文件在提高頁面加載速度和跨域問題上有非常重要的作用。上面就是一個(gè)簡單例子。

ie 上支持 onreadystatechange , 不支持 onload

firefox上支持 onload , 不支持onreadystatechange

ie上面不一定loaded 或者是 complete觸發(fā) , 或者兩個(gè)都會(huì)觸發(fā),所以用或來判斷。

需要注意的是script.onreadystatechange 和script.readyState 的大小寫形式,不區(qū)分大小寫就可能導(dǎo)致不易發(fā)現(xiàn)的錯(cuò)誤。

感謝各位的閱讀,以上就是“JS怎么實(shí)現(xiàn)動(dòng)態(tài)插入并立即執(zhí)行回調(diào)函數(shù)”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)JS怎么實(shí)現(xiàn)動(dòng)態(tài)插入并立即執(zhí)行回調(diào)函數(shù)這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI