Web動態(tài)加載js

很多時候在一個頁面中某個操作需要用到一個js庫潦俺,但這個操作也不經(jīng)常用,所以并不想在該頁面一開始就加載這個js庫邻奠,只有當(dāng)操作時才動態(tài)加載進來阅羹。

由于瀏覽器(DOM)對象允許javascript動態(tài)創(chuàng)建任何HTML內(nèi)容,并自動根據(jù)鏈接下載內(nèi)容一罩,像<img src="..." />``<script src="...">等杨幼,所以只需向DOM中添加<script>內(nèi)容就好了撇簿,關(guān)鍵在于怎樣知道瀏覽器什么時候加載完js聂渊,不然我們依賴該js的代碼就會出錯,

Chrome/Firefox/safari/IE11 等在<script>內(nèi)容加載完后會有一個load事件四瘫,我們可監(jiān)聽這一事來完成需要的相關(guān)操作

var script = document.createElement("script");
script.onload = function(){
    ///加載完成
}
script.src = "file.js";
document.getElementByTagName("head")[0].appendChild(script);

而IE11以下版本就不支持此事件汉嗽,但會有一個readystatechange事件:

script.readystatechange = function(){
    if( script.readyState == "loaded" || script.readyState == "complete" ){
        ///加載完成
    }
}

下面來封裝下,以方便調(diào)用:

function loadScript(url, callback){
    var script = document.createElement ("script")
    script.type = "text/javascript";
    if (script.readyState){ //IE
        script.onreadystatechange = function(){
            if (script.readyState == "loaded" || script.readyState == "complete"){
                script.onreadystatechange = null;
                callback();
            }
        };
    } else { //Others
        script.onload = function(){
            callback();
        };
    }
    script.src = url;
    document.getElementsByTagName("head")[0].appendChild(script);
}

現(xiàn)在就可以當(dāng)點擊時再加載所需js庫找蜜,但當(dāng)重復(fù)點擊時饼暑,就會重復(fù)加載,所以我們還需要一個變量記錄已動態(tài)加載的js,以防止重復(fù)加載

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末弓叛,一起剝皮案震驚了整個濱河市彰居,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌撰筷,老刑警劉巖陈惰,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異毕籽,居然都是意外死亡抬闯,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進店門关筒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來溶握,“玉大人,你說我怎么就攤上這事蒸播∷埽” “怎么了?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵袍榆,是天一觀的道長肉微。 經(jīng)常有香客問我,道長蜡塌,這世上最難降的妖魔是什么碉纳? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮馏艾,結(jié)果婚禮上劳曹,老公的妹妹穿的比我還像新娘。我一直安慰自己琅摩,他們只是感情好铁孵,可當(dāng)我...
    茶點故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著房资,像睡著了一般蜕劝。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上轰异,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天岖沛,我揣著相機與錄音,去河邊找鬼搭独。 笑死婴削,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的牙肝。 我是一名探鬼主播唉俗,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼嗤朴,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了虫溜?” 一聲冷哼從身側(cè)響起雹姊,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎衡楞,沒想到半個月后容为,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡寺酪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年坎背,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寄雀。...
    茶點故事閱讀 39,769評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡得滤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出盒犹,到底是詐尸還是另有隱情懂更,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布急膀,位于F島的核電站沮协,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏卓嫂。R本人自食惡果不足惜慷暂,卻給世界環(huán)境...
    茶點故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望晨雳。 院中可真熱鬧行瑞,春花似錦、人聲如沸餐禁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽帮非。三九已至氧吐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間末盔,已是汗流浹背筑舅。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留庄岖,地道東北人豁翎。 一個月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓角骤,卻偏偏與公主長得像隅忿,于是被迫代替她去往敵國和親心剥。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,678評論 2 354

推薦閱讀更多精彩內(nèi)容

  • ( 摘自高性能Javascript )文檔對象模型(DOM)允許你使用JavaScript 動態(tài)創(chuàng)建HTML的幾乎...
    jicemoon閱讀 17,589評論 6 25
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,095評論 25 707
  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案背桐? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽?zāi)J的外補...
    _Yfling閱讀 13,751評論 1 92
  • 湘江的水 擊打著岸邊 似乎要將明月?lián)羲?靠在護欄的情侶 親吻著 顧不上湘江的水 汽笛聲和一年前一樣 只不過少了只顧...
    小罪人閱讀 381評論 4 14
  • 生產(chǎn)環(huán)境中优烧,經(jīng)常會因為系統(tǒng)迭代升級而修改表結(jié)構(gòu)。如果遇到了對大表做添加有default值字段的操作链峭,一定要格外注意...
    DBA閱讀 2,205評論 1 6