動(dòng)態(tài)加載JavaScript文件的兩種方法
來(lái)源:易賢網(wǎng) 閱讀:707 次 日期:2016-07-06 16:28:44
溫馨提示:易賢網(wǎng)小編為您整理了“動(dòng)態(tài)加載JavaScript文件的兩種方法”,方便廣大網(wǎng)友查閱!

第一種利用ajax方式,第二種是動(dòng)靜創(chuàng)建一個(gè)script標(biāo)簽,配置其src屬性,經(jīng)過(guò)把script標(biāo)簽拔出到頁(yè)面head來(lái)加載js,感樂(lè)趣的網(wǎng)友可以看下

這篇文章主要為大家詳細(xì)介紹了動(dòng)態(tài)加載JavaScript文件的兩種方法,感興趣的小伙伴們可以參考一下

第一種便是利用ajax方式,把script文件代碼從背景加載到前臺(tái),而后對(duì)加載到的內(nèi)容經(jīng)過(guò)eval()實(shí)施代碼。第二種是,動(dòng)靜創(chuàng)建一個(gè)script標(biāo)簽,配置其src屬性,經(jīng)過(guò)把script標(biāo)簽插入到頁(yè)面head來(lái)加載js,相當(dāng)于正在head中寫了一個(gè)<script src="..."></script>,只可是這個(gè)script標(biāo)簽是用js動(dòng)靜創(chuàng)建的

比喻說(shuō)是我們要?jiǎng)屿o地加載一個(gè)callbakc.js,我們就必要多么一個(gè)script標(biāo)簽:

代碼如下:

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

如下代碼就是如何通過(guò)js來(lái)創(chuàng)建這個(gè)標(biāo)簽(并且加到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)用其中的方法。不過(guò)在header.appendChild(script)之后我們不能馬上調(diào)用其中的js。因?yàn)闉g覽器是異步加載這個(gè)js的,我們不知道他什么時(shí)候加載完。然而我們可以通過(guò)監(jiān)聽(tīng)事件的辦法來(lái)判斷helper.js是否加載完成。(假設(shè)call.js中有一個(gè)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個(gè)事件監(jiān)聽(tīng)函數(shù), 因?yàn)樵趇e中使用onreadystatechange, 而gecko,webkit 瀏覽器和opera都支持onload。事實(shí)上this.readyState == 'complete'并不能工作的很好,理論上狀態(tài)的變化是如下步驟:

1.uninitialized

2.loading

3.loaded

4.interactive

5.complete

但是有些狀態(tài)會(huì)被跳過(guò)。根據(jù)經(jīng)驗(yàn)在ie7中,只能獲得loaded和completed中的一個(gè),不能都出現(xiàn),原因也許是對(duì)判斷是不是從cache中讀取影響了狀態(tài)的變化,也可能是其他原因。最好把判斷條件改成this.readyState == 'loaded' || this.readyState == 'complete'

參考jQuery的實(shí)現(xiàn)我們最后實(shí)現(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);

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

另外需要注意:

1.因?yàn)閟cript標(biāo)簽的src可以跨域訪問(wèn)資源,所以這種方法可以模擬ajax,解決ajax跨域訪問(wèn)的問(wèn)題。

2.如果用ajax返回的html代碼中包含script,則直接用innerHTML插入到dom中是不能使html中的script起作用的。粗略的看了下jQuery().html(html)的原代碼,jQuery也是先解析傳入的參數(shù),剝離其中的script代碼,動(dòng)態(tài)創(chuàng)建script標(biāo)簽,所用jQuery的html方法添加進(jìn)dom的html如果包含script是可以執(zhí)行的。如:

代碼如下:

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

以上就是動(dòng)態(tài)加載JavaScript文件的方法,希望對(duì)大家的學(xué)習(xí)有所幫助。

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:動(dòng)態(tài)加載JavaScript文件的兩種方法
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)