亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

動態加載JavaScript文件的兩種方法

2019-11-20 10:14:00
字體:
來源:轉載
供稿:網友

這篇文章主要為大家詳細介紹了動態加載JavaScript文件的兩種方法,感興趣的小伙伴們可以參考一下
第一種便是利用ajax方式,把script文件代碼從背景加載到前臺,而后對加載到的內容經過eval()實施代碼。第二種是,動靜創建一個script標簽,配置其src屬性,經過把script標簽插入到頁面head來加載js,相當于正在head中寫了一個<script src="..."></script>,只可是這個script標簽是用js動靜創建的
比喻說是我們要動靜地加載一個callbakc.js,我們就必要多么一個script標簽:
代碼如下:  

復制代碼 代碼如下:
<script type="text/javascript" src="call.js"></script>

如下代碼就是如何通過js來創建這個標簽(并且加到head中): 
代碼如下:

var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.src= 'call.js'; head.appendChild(script); 

當加載完call.js, 我們就要調用其中的方法。不過在header.appendChild(script)之后我們不能馬上調用其中的js。因為瀏覽器是異步加載這個js的,我們不知道他什么時候加載完。然而我們可以通過監聽事件的辦法來判斷helper.js是否加載完成。(假設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);

我設了2個事件監聽函數, 因為在ie中使用onreadystatechange, 而gecko,webkit 瀏覽器和opera都支持onload。事實上this.readyState == 'complete'并不能工作的很好,理論上狀態的變化是如下步驟:
1.uninitialized
2.loading
3.loaded
4.interactive
5.complete
但是有些狀態會被跳過。根據經驗在ie7中,只能獲得loaded和completed中的一個,不能都出現,原因也許是對判斷是不是從cache中讀取影響了狀態的變化,也可能是其他原因。最好把判斷條件改成this.readyState == 'loaded' || this.readyState == 'complete'

參考jQuery的實現我們最后實現為: 代碼如下: 

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()的調用寫在helper.js的最后,那么可以保證在helper.js在加載完后能自動調用help(),當然最后還要能這樣是不是適合你的應用。

另外需要注意:

1.因為script標簽的src可以跨域訪問資源,所以這種方法可以模擬ajax,解決ajax跨域訪問的問題。
2.如果用ajax返回的html代碼中包含script,則直接用innerHTML插入到dom中是不能使html中的script起作用的。粗略的看了下jQuery().html(html)的原代碼,jQuery也是先解析傳入的參數,剝離其中的script代碼,動態創建script標簽,所用jQuery的html方法添加進dom的html如果包含script是可以執行的。如:  
 

復制代碼 代碼如下:
jQuery("#content").html("<script>alert('aa');<//script>");

以上就是動態加載JavaScript文件的方法,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人精品在线视频| 欧美成人精品在线| 91精品国产高清| 久久99久国产精品黄毛片入口| 亚洲第一综合天堂另类专| 精品久久久久久久久久国产| 亚洲影院色在线观看免费| 日韩在线视频观看| 精品亚洲夜色av98在线观看| 欧美在线一级视频| 日韩亚洲欧美中文高清在线| 亚洲欧美国产高清va在线播| 成人欧美一区二区三区在线湿哒哒| 亚洲国产精品悠悠久久琪琪| xvideos亚洲人网站| 久久久久久中文字幕| 亚洲人免费视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲第一视频网| 亚洲色在线视频| 日韩av在线免费观看一区| 欧美激情视频在线观看| 97香蕉超级碰碰久久免费软件| 久久综合久中文字幕青草| 亚洲精品成a人在线观看| 亚洲国产小视频在线观看| 亚洲欧美国产视频| 欧美精品www在线观看| 欧美亚洲成人xxx| 亚洲精品福利免费在线观看| 一区二区中文字幕| 亚洲图中文字幕| 午夜美女久久久久爽久久| 国产美女被下药99| 国产盗摄xxxx视频xxx69| 色综合久久88| 超薄丝袜一区二区| 亚洲国产精品一区二区久| 欧美日韩国产丝袜美女| 在线观看日韩www视频免费| 日韩欧美一区二区在线| 黑人巨大精品欧美一区免费视频| 一道本无吗dⅴd在线播放一区| 久久久视频免费观看| 55夜色66夜色国产精品视频| 亚洲福利精品在线| 69av视频在线播放| 大胆人体色综合| 亚洲国产高清自拍| 欧美大秀在线观看| 久色乳综合思思在线视频| 国内免费精品永久在线视频| 日韩电影在线观看永久视频免费网站| 欧美裸体男粗大视频在线观看| 亚洲高清久久网| 91成人在线视频| 欧美精品激情blacked18| 精品中文字幕视频| 国产成人精品日本亚洲| 久久影视电视剧免费网站| 中文字幕不卡av| 国产精品久久久久久av福利软件| 在线精品国产成人综合| 成人免费视频在线观看超级碰| 精品久久久久久中文字幕| 国外色69视频在线观看| 最近中文字幕日韩精品| 美女少妇精品视频| 黑人欧美xxxx| 国产亚洲欧美日韩一区二区| 欧美午夜片欧美片在线观看| 欧美日韩第一页| 成人国产精品久久久久久亚洲| 色樱桃影院亚洲精品影院| 91精品国产综合久久香蕉922| 国产丝袜一区视频在线观看| 日韩精品中文字幕视频在线| 国产一区二区三区毛片| 亚洲天堂av在线免费| 日本在线精品视频| 中文字幕国内精品| 日韩成人性视频| 日韩中文字幕网站| 国产精品成人免费视频| 成人午夜黄色影院| 色婷婷亚洲mv天堂mv在影片| 成人免费视频网址| 国产精品网站大全| 国产91色在线免费| 91精品国产九九九久久久亚洲| 亚洲激情中文字幕| 亚洲韩国欧洲国产日产av| 在线日韩av观看| 色噜噜狠狠狠综合曰曰曰88av| 欧美一级大片在线观看| 亚洲free嫩bbb| 中文字幕在线亚洲| 欧美大片免费观看在线观看网站推荐| 亚洲欧美日本另类| 欧美日韩精品在线播放| 亚洲新声在线观看| 在线观看日韩www视频免费| 日韩av在线免费看| xxx一区二区| 国产精品福利久久久| 精品国产一区二区三区四区在线观看| 国产精品男女猛烈高潮激情| 精品久久久久久久久久久| 深夜成人在线观看| 精品视频中文字幕| 成人h猎奇视频网站| 不卡av电影在线观看| 91国语精品自产拍在线观看性色| 黄色精品一区二区| 欧美专区福利在线| 欧美性少妇18aaaa视频| 中文字幕欧美日韩| 国产99久久精品一区二区| 亚洲精品久久久一区二区三区| 欧美国产极速在线| 亚洲国产成人精品久久| 国产在线拍偷自揄拍精品| 国产精品爽黄69| 日韩在线观看免费高清完整版| 久久夜色精品国产亚洲aⅴ| 中文字幕精品在线| 欧美午夜片欧美片在线观看| 日韩在线视频国产| 亚洲国产欧美日韩精品| 欧美在线视频观看免费网站| 国产精品美女www爽爽爽视频| 国产精品视频男人的天堂| 亚洲天堂2020| 国产精品免费一区| 红桃av永久久久| 久久精品国产91精品亚洲| 91在线高清视频| 国产成人在线精品| 国产亚洲一区二区在线| 国产99视频在线观看| 久久网福利资源网站| 欧美成aaa人片免费看| 色七七影院综合| 亚洲大尺度美女在线| 色妞久久福利网| 日本电影亚洲天堂| www.欧美视频| www.亚洲天堂| 欧美日韩在线视频一区二区| 中文字幕亚洲二区| 亚洲免费精彩视频| 日韩av在线导航| 亚洲性无码av在线| 中文字幕日韩欧美| 精品久久久久国产| 久久久久国产精品www| 亚洲视频在线观看网站| 国产精品黄页免费高清在线观看| 亚洲曰本av电影| 国产精品久久久久久久久久久新郎| 色综合影院在线| 91精品国产综合久久久久久久久| 亚洲免费高清视频| 国产91精品在线播放|