国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

動態加載script文件的兩種方法

2024-05-06 15:50:40
字體:
來源:轉載
供稿:網友
第一種就是利用ajax方式,第二種是,動態創建一個script標簽,設置其src屬性,通過把script標簽插入到頁面head來加載js,感興趣的朋友可以了解下

動態加載script到頁面大約有倆方法

第一種就是利用ajax方式,把script文件代碼從后臺加載到前臺,然后對加載到的內容通過eval()執行代碼。第二種是,動態創建一個script標簽,設置其src屬性,通過把script標簽插入到頁面head來加載js,相當于在head中寫了一個<script src="..."></script>,只不過這個script標簽是用js動態創建的
比如說是我們要動態地加載一個callbakc.js,我們就需要這樣一個script標簽:

復制代碼 代碼如下:


<script type="text/javascript" src="call.js"></script>


如下代碼就是如何通過js來創建這個標簽(并且加到head中):

復制代碼 代碼如下:


var head= document.getElementsByTagName('head')[0];
var script= document.createElement('script');
script.type= 'text/javascript';
script.src= 'call.js';
head.appendChild(script);


當加載完call.js, 我們就要調用其中的方法。不過在header.appendChild(script)之后我們不能馬上調用其中的js。因為瀏覽器是異步加載這個js的,我們不知道他什么時候加載完。然而我們可以通過監聽事件的辦法來判斷helper.js是否加載完成。(假設call.js中有一個callback方法)

復制代碼 代碼如下:


var head= document.getElementsByTagName('head')[0];
var script= document.createElement('script');
script.type= 'text/javascript';
script.onreadystatechange= function () {
if (this.readyState == 'complete')
callback();
}
script.onload= function(){
callback();
}
script.src= 'helper.js';
head.appendChild(script);


我設了2個事件監聽函數, 因為在ie中使用onreadystatechange, 而gecko,webkit 瀏覽器和opera都支持onload。事實上this.readyState == 'complete'并不能工作的很好,理論上狀態的變化是如下步驟:
0 uninitialized
1 loading
2 loaded
3 interactive
4 complete
但是有些狀態會被跳過。根據經驗在ie7中,只能獲得loaded和completed中的一個,不能都出現,原因也許是對判斷是不是從cache中讀取影響了狀態的變化,也可能是其他原因。最好把判斷條件改成this.readyState == 'loaded' || this.readyState == 'complete'

參考jQuery的實現我們最后實現為:

復制代碼 代碼如下:


var head= document.getElementsByTagName('head')[0];
var script= document.createElement('script');
script.type= 'text/javascript';
script.onload = script.onreadystatechange = function() {
if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete" ) {
help();
// Handle memory leak in IE
script.onload = script.onreadystatechange = null;
} };
script.src= 'helper.js';
head.appendChild(script);


還有一種簡單的情況就是可以把help()的調用寫在helper.js的最后,那么可以保證在helper.js在加載完后能自動調用help(),當然最后還要能這樣是不是適合你的應用。

另外需要注意:

1.因為script標簽的src可以跨域訪問資源,所以這種方法可以模擬ajax,解決ajax跨域訪問的問題。
2.如果用ajax返回的html代碼中包含script,則直接用innerHTML插入到dom中是不能使html中的script起作用的。粗略的看了下jQuery().html(html)的原代碼,jQuery也是先解析傳入的參數,剝離其中的script代碼,動態創建script標簽,所用jQuery的html方法添加進dom的html如果包含script是可以執行的。如:

復制代碼 代碼如下:


jQuery("#content").html("<script>alert('aa');<//script>");

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 伊金霍洛旗| 库尔勒市| 寻乌县| 天长市| 惠水县| 台山市| 广丰县| 吕梁市| 长顺县| 通渭县| 昭觉县| 阜新市| 琼结县| 屏山县| 云林县| 莱西市| 凤台县| 察哈| 洪洞县| 永仁县| 松江区| 洱源县| 株洲市| 聂拉木县| 沂源县| 大名县| 淮北市| 静宁县| 安陆市| 东港市| 石屏县| 望江县| 开封市| 图片| 大荔县| 福海县| 大同县| 前郭尔| 夹江县| 都昌县| 余姚市|