亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

動(dòng)態(tài)加載script文件的兩種方法

 更新時(shí)間:2013年08月15日 19:27:28   作者:  
第一種就是利用ajax方式,第二種是,動(dòng)態(tài)創(chuàng)建一個(gè)script標(biāo)簽,設(shè)置其src屬性,通過把script標(biāo)簽插入到頁面head來加載js,感興趣的朋友可以了解下
動(dòng)態(tài)加載script到頁面大約有倆方法

第一種就是利用ajax方式,把script文件代碼從后臺加載到前臺,然后對加載到的內(nèi)容通過eval()執(zhí)行代碼。第二種是,動(dòng)態(tài)創(chuàng)建一個(gè)script標(biāo)簽,設(shè)置其src屬性,通過把script標(biāo)簽插入到頁面head來加載js,相當(dāng)于在head中寫了一個(gè)<script src="..."></script>,只不過這個(gè)script標(biāo)簽是用js動(dòng)態(tài)創(chuàng)建的
比如說是我們要?jiǎng)討B(tài)地加載一個(gè)callbakc.js,我們就需要這樣一個(gè)script標(biāo)簽:
復(fù)制代碼 代碼如下:

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

如下代碼就是如何通過js來創(chuàng)建這個(gè)標(biāo)簽(并且加到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。因?yàn)闉g覽器是異步加載這個(gè)js的,我們不知道他什么時(shí)候加載完。然而我們可以通過監(jiān)聽事件的辦法來判斷helper.js是否加載完成。(假設(shè)call.js中有一個(gè)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個(gè)事件監(jiān)聽函數(shù), 因?yàn)樵趇e中使用onreadystatechange, 而gecko,webkit 瀏覽器和opera都支持onload。事實(shí)上this.readyState == 'complete'并不能工作的很好,理論上狀態(tài)的變化是如下步驟:
0 uninitialized
1 loading
2 loaded
3 interactive
4 complete
但是有些狀態(tài)會(huì)被跳過。根據(jù)經(jīng)驗(yàn)在ie7中,只能獲得loaded和completed中的一個(gè),不能都出現(xiàn),原因也許是對判斷是不是從cache中讀取影響了狀態(tài)的變化,也可能是其他原因。最好把判斷條件改成this.readyState == 'loaded' || this.readyState == 'complete'

參考jQuery的實(shí)現(xiàn)我們最后實(shí)現(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在加載完后能自動(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í)行的。如:
復(fù)制代碼 代碼如下:

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

相關(guān)文章

  • js獲取及判斷鍵盤按鍵的方法

    js獲取及判斷鍵盤按鍵的方法

    這篇文章主要介紹了js獲取及判斷鍵盤按鍵的方法,涉及JavaScript鍵盤事件的獲取及鍵值的判定技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-12-12
  • 關(guān)于 byval 與 byref 的區(qū)別分析總結(jié)

    關(guān)于 byval 與 byref 的區(qū)別分析總結(jié)

    關(guān)于 byval 與 byref 的區(qū)別分析總結(jié)...
    2007-10-10
  • JS使用new操作符創(chuàng)建對象的方法分析

    JS使用new操作符創(chuàng)建對象的方法分析

    這篇文章主要介紹了JS使用new操作符創(chuàng)建對象的方法,結(jié)合實(shí)例形式分析了javascript面向?qū)ο蟪绦蛟O(shè)計(jì)類的定義、new操作符對象的創(chuàng)建及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-05-05
  • 詳解微信小程序-掃一掃 wx.scanCode() 掃碼大變身

    詳解微信小程序-掃一掃 wx.scanCode() 掃碼大變身

    這篇文章主要介紹了微信小程序-掃一掃wx.scanCode() 掃碼大變身,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 微信小程序?qū)崿F(xiàn)圖片壓縮功能

    微信小程序?qū)崿F(xiàn)圖片壓縮功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)圖片壓縮功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Bootstrap零基礎(chǔ)學(xué)習(xí)第一課之模板

    Bootstrap零基礎(chǔ)學(xué)習(xí)第一課之模板

    這篇文章主要為大家詳細(xì)介紹了Bootstrap零基礎(chǔ)學(xué)習(xí)第一課:模板,感興趣的小伙伴們可以參考一下
    2016-07-07
  • 快速掌握WordPress中加載JavaScript腳本的方法

    快速掌握WordPress中加載JavaScript腳本的方法

    這篇文章主要介紹了快速掌握WordPress中加載JavaScript腳本的方法,以及響應(yīng)的CSS樣式加載方法的簡介,需要的朋友可以參考下
    2015-12-12
  • js獲取url傳值的方法

    js獲取url傳值的方法

    這篇文章主要介紹了js獲取url傳值的方法,實(shí)例分析了字符串分割與正則分析兩種方法,并補(bǔ)充了一個(gè)基于正則匹配實(shí)現(xiàn)的js獲取url的get傳值函數(shù),需要的朋友可以參考下
    2015-12-12
  • javascript實(shí)現(xiàn)跨域的方法匯總

    javascript實(shí)現(xiàn)跨域的方法匯總

    這篇文章主要給大家匯總介紹了javascript實(shí)現(xiàn)跨域的方法的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • js+canvas繪制圖形驗(yàn)證碼

    js+canvas繪制圖形驗(yàn)證碼

    這篇文章主要為大家詳細(xì)介紹了js+canvas繪制圖形驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09

最新評論