動態(tài)加載script文件的兩種方法
更新時間:2013年08月15日 19:27:28 作者:
第一種就是利用ajax方式,第二種是,動態(tài)創(chuàng)建一個script標簽,設(shè)置其src屬性,通過把script標簽插入到頁面head來加載js,感興趣的朋友可以了解下
動態(tài)加載script到頁面大約有倆方法
第一種就是利用ajax方式,把script文件代碼從后臺加載到前臺,然后對加載到的內(nèi)容通過eval()執(zhí)行代碼。第二種是,動態(tài)創(chuàng)建一個script標簽,設(shè)置其src屬性,通過把script標簽插入到頁面head來加載js,相當(dāng)于在head中寫了一個<script src="..."></script>,只不過這個script標簽是用js動態(tài)創(chuàng)建的
比如說是我們要動態(tài)地加載一個callbakc.js,我們就需要這樣一個script標簽:
<script type="text/javascript" src="call.js"></script>
如下代碼就是如何通過js來創(chuàng)建這個標簽(并且加到head中):
var head= document.getElementsByTagName('head')[0];
var script= document.createElement('script');
script.type= 'text/javascript';
script.src= 'call.js';
head.appendChild(script);
當(dāng)加載完call.js, 我們就要調(diào)用其中的方法。不過在header.appendChild(script)之后我們不能馬上調(diào)用其中的js。因為瀏覽器是異步加載這個js的,我們不知道他什么時候加載完。然而我們可以通過監(jiān)聽事件的辦法來判斷helper.js是否加載完成。(假設(shè)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);
我設(shè)了2個事件監(jiān)聽函數(shù), 因為在ie中使用onreadystatechange, 而gecko,webkit 瀏覽器和opera都支持onload。事實上this.readyState == 'complete'并不能工作的很好,理論上狀態(tài)的變化是如下步驟:
0 uninitialized
1 loading
2 loaded
3 interactive
4 complete
但是有些狀態(tài)會被跳過。根據(jù)經(jīng)驗在ie7中,只能獲得loaded和completed中的一個,不能都出現(xiàn),原因也許是對判斷是不是從cache中讀取影響了狀態(tài)的變化,也可能是其他原因。最好把判斷條件改成this.readyState == 'loaded' || this.readyState == 'complete'
參考jQuery的實現(xiàn)我們最后實現(xiàn)為:
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()的調(diào)用寫在helper.js的最后,那么可以保證在helper.js在加載完后能自動調(diào)用help(),當(dāng)然最后還要能這樣是不是適合你的應(yīng)用。
另外需要注意:
1.因為script標簽的src可以跨域訪問資源,所以這種方法可以模擬ajax,解決ajax跨域訪問的問題。
2.如果用ajax返回的html代碼中包含script,則直接用innerHTML插入到dom中是不能使html中的script起作用的。粗略的看了下jQuery().html(html)的原代碼,jQuery也是先解析傳入的參數(shù),剝離其中的script代碼,動態(tài)創(chuàng)建script標簽,所用jQuery的html方法添加進dom的html如果包含script是可以執(zhí)行的。如:
jQuery("#content").html("<script>alert('aa');<\/script>");
第一種就是利用ajax方式,把script文件代碼從后臺加載到前臺,然后對加載到的內(nèi)容通過eval()執(zhí)行代碼。第二種是,動態(tài)創(chuàng)建一個script標簽,設(shè)置其src屬性,通過把script標簽插入到頁面head來加載js,相當(dāng)于在head中寫了一個<script src="..."></script>,只不過這個script標簽是用js動態(tài)創(chuàng)建的
比如說是我們要動態(tài)地加載一個callbakc.js,我們就需要這樣一個script標簽:
復(fù)制代碼 代碼如下:
<script type="text/javascript" src="call.js"></script>
如下代碼就是如何通過js來創(chuàng)建這個標簽(并且加到head中):
復(fù)制代碼 代碼如下:
var head= document.getElementsByTagName('head')[0];
var script= document.createElement('script');
script.type= 'text/javascript';
script.src= 'call.js';
head.appendChild(script);
當(dāng)加載完call.js, 我們就要調(diào)用其中的方法。不過在header.appendChild(script)之后我們不能馬上調(diào)用其中的js。因為瀏覽器是異步加載這個js的,我們不知道他什么時候加載完。然而我們可以通過監(jiān)聽事件的辦法來判斷helper.js是否加載完成。(假設(shè)call.js中有一個callback方法)
復(fù)制代碼 代碼如下:
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);
我設(shè)了2個事件監(jiān)聽函數(shù), 因為在ie中使用onreadystatechange, 而gecko,webkit 瀏覽器和opera都支持onload。事實上this.readyState == 'complete'并不能工作的很好,理論上狀態(tài)的變化是如下步驟:
0 uninitialized
1 loading
2 loaded
3 interactive
4 complete
但是有些狀態(tài)會被跳過。根據(jù)經(jīng)驗在ie7中,只能獲得loaded和completed中的一個,不能都出現(xiàn),原因也許是對判斷是不是從cache中讀取影響了狀態(tài)的變化,也可能是其他原因。最好把判斷條件改成this.readyState == 'loaded' || this.readyState == 'complete'
參考jQuery的實現(xiàn)我們最后實現(xiàn)為:
復(fù)制代碼 代碼如下:
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()的調(diào)用寫在helper.js的最后,那么可以保證在helper.js在加載完后能自動調(diào)用help(),當(dāng)然最后還要能這樣是不是適合你的應(yīng)用。
另外需要注意:
1.因為script標簽的src可以跨域訪問資源,所以這種方法可以模擬ajax,解決ajax跨域訪問的問題。
2.如果用ajax返回的html代碼中包含script,則直接用innerHTML插入到dom中是不能使html中的script起作用的。粗略的看了下jQuery().html(html)的原代碼,jQuery也是先解析傳入的參數(shù),剝離其中的script代碼,動態(tài)創(chuàng)建script標簽,所用jQuery的html方法添加進dom的html如果包含script是可以執(zhí)行的。如:
復(fù)制代碼 代碼如下:
jQuery("#content").html("<script>alert('aa');<\/script>");
相關(guān)文章
JavaScript實踐之使用Canvas開發(fā)一個可配置的大轉(zhuǎn)盤抽獎功能
公司項目搞優(yōu)惠活動,讓做一個轉(zhuǎn)盤抽獎的活動,這篇文章主要給大家介紹了關(guān)于JavaScript實踐之使用Canvas開發(fā)一個可配置的大轉(zhuǎn)盤抽獎功能的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-11-11
js簡單實現(xiàn)表單中點擊按鈕動態(tài)增加輸入框數(shù)量的方法
這篇文章主要介紹了js簡單實現(xiàn)表單中點擊按鈕動態(tài)增加輸入框數(shù)量的方法,涉及javascript鼠標點擊事件及insertAdjacentHTML方法的相關(guān)使用技巧,需要的朋友可以參考下2015-08-08
js中async函數(shù)結(jié)合promise的小案例淺析
這篇文章主要介紹了js中async函數(shù)結(jié)合promise的小案例淺析,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04
el-date-picker與el-time-picker的時間格式設(shè)置代碼
這篇文章主要介紹了el-date-picker與el-time-picker的時間格式設(shè)置代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11
JavaScript實現(xiàn)星座查詢功能 附詳細代碼
最近小編在做一個項目,其中涉及到一個模塊關(guān)于星座查詢功能,即在文本框中輸入一個生日值,點擊按鈕可以得到對應(yīng)的星座,怎么實現(xiàn)這個需求呢?下面小編通過示例代碼給大家介紹下,需要的朋友參考下吧2021-11-11

