動(dòng)態(tài)加載JavaScript文件的兩種方法
這篇文章主要為大家詳細(xì)介紹了動(dòng)態(tài)加載JavaScript文件的兩種方法,感興趣的小伙伴們可以參考一下
第一種便是利用ajax方式,把script文件代碼從背景加載到前臺(tái),而后對(duì)加載到的內(nèi)容經(jīng)過eval()實(shí)施代碼。第二種是,動(dòng)靜創(chuàng)建一個(gè)script標(biāo)簽,配置其src屬性,經(jīng)過把script標(biāo)簽插入到頁面head來加載js,相當(dāng)于正在head中寫了一個(gè)<script src="..."></script>,只可是這個(gè)script標(biāo)簽是用js動(dòng)靜創(chuàng)建的
比喻說是我們要?jiǎng)屿o地加載一個(gè)callbakc.js,我們就必要多么一個(gè)script標(biāo)簽:
代碼如下:
如下代碼就是如何通過js來創(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)用其中的方法。不過在header.appendChild(script)之后我們不能馬上調(diào)用其中的js。因?yàn)闉g覽器是異步加載這個(gè)js的,我們不知道他什么時(shí)候加載完。然而我們可以通過監(jiān)聽事件的辦法來判斷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)聽函數(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ì)被跳過。根據(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可以跨域訪問資源,所以這種方法可以模擬ajax,解決ajax跨域訪問的問題。
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í)行的。如:
以上就是動(dòng)態(tài)加載JavaScript文件的方法,希望對(duì)大家的學(xué)習(xí)有所幫助。
- 學(xué)習(xí)javascript文件加載優(yōu)化
- 理解Javascript文件動(dòng)態(tài)加載
- JS 動(dòng)態(tài)加載js文件和css文件 同步/異步的兩種簡(jiǎn)單方式
- JS加載器如何動(dòng)態(tài)加載外部js文件
- 動(dòng)態(tài)加載js、css的簡(jiǎn)單實(shí)現(xiàn)代碼
- 動(dòng)態(tài)加載js、css的實(shí)例代碼
- 動(dòng)態(tài)加載js文件簡(jiǎn)單示例
- jquery及js實(shí)現(xiàn)動(dòng)態(tài)加載js文件的方法
- 如何動(dòng)態(tài)加載外部Javascript文件
- js實(shí)現(xiàn)動(dòng)態(tài)加載腳本的方法實(shí)例匯總
- 不使用script導(dǎo)入js文件的幾種方法
相關(guān)文章
javascript oop開發(fā)滑動(dòng)(slide)菜單控件
這里因?yàn)槭茄菔舅宰孒TML CSS盡量的簡(jiǎn)化,另外使用jquery的 fn.slideUp fn.slideDown 實(shí)現(xiàn)起來會(huì)更容易不過我作為一個(gè)專業(yè)的開發(fā)者多了解些原生的JS對(duì)技術(shù)的提高還是很有幫助。2010-08-08
解析JavaScript實(shí)現(xiàn)DDoS攻擊原理與保護(hù)措施
本文主要對(duì)JavaScript實(shí)現(xiàn)DDoS攻擊原理與保護(hù)措施進(jìn)行介紹,具有一定的參考價(jià)值,需要的朋友一起來看下吧2016-12-12
JavaScript 特有方法計(jì)算二進(jìn)制中1的個(gè)數(shù) split方法
這是一道網(wǎng)上看到的前端的筆試題,主要思想是利用JavaScript的toString方法將十進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制的字符串。然后for循環(huán)遍歷計(jì)算字符串中”1″出現(xiàn)的次數(shù)。2010-05-05
JavaScript利用HTML DOM進(jìn)行文檔操作的方法
DOM是W3C制定的用于訪問諸如XML和XHTML等結(jié)構(gòu)化文檔的標(biāo)準(zhǔn)。通過本文給大家介紹JavaScript利用HTML DOM進(jìn)行文檔操作的方法,需要的朋友參考下吧2016-03-03
javascript實(shí)現(xiàn)文字無縫滾動(dòng)
這篇文章主要介紹了javascript實(shí)現(xiàn)文字無縫滾動(dòng),文字可以實(shí)現(xiàn)上下滾動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
JS繼承實(shí)現(xiàn)方法及優(yōu)缺點(diǎn)詳解
這篇文章主要介紹了JS繼承實(shí)現(xiàn)方法及優(yōu)缺點(diǎn)詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
bootstrap 設(shè)置checkbox部分選中效果
本篇文章主要介紹了bootstrap 設(shè)置checkbox部分選中效果,主要涉及到j(luò)s各個(gè)方面的內(nèi)容,對(duì)于bootstrap設(shè)置checkbox選中效果感興趣的朋友可以參考一下吧2017-04-04

