ensure({ html: "popup.html", javascript: "popup.js", css: "popup.css" }, function() { Popup.show("hello world"); } ); 在這段代碼中,ensure首先會確保popup " /> 精品一区二区三区久久,aaaa免费视频,在线免费观看日韩av

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

多瀏覽器兼容的動態加載 JavaScript 與 CSS第1/2頁

在介紹ensure內部的實現之前,讓我們先來看看其功能:

ensure({
html: "popup.html",
Javascript: "popup.js",
css: "popup.css"
}, function() {
Popup.show("hello world");
}
);
在這段代碼中,ensure首先會確保popup.html、popup.js、popup.css這3個文件的加載,如果都沒加載過ensure就會動態加載它們;如果已經加載過了,ensure不會再次加載。在確保這3個文件都加載后,ensure會調用后面的匿名函數,也就是執行Popup.show("hello world");。

接下來,就讓我們看看ensure是如何動態加載JavaScript與CSS的。

加載JavaScript
在ensure當中,加載JavaScript分兩種情況來執行,也就是Safari與非Safari這兩種情況。

在IE、Firefox、Opera中加載JavaScript
在這三款瀏覽器中加載JavaScript,其實只需要創建一個script元素,把src指向要加載的URL,最后把script元素追加到head元素上,那就搞掂了。此項工作是在HttpLibrary.createScriptTag()中完成的。不過我們不僅僅要加載JavaScript,同時還需要知道它什么時候完成加載,這可以通過script元素的onload事件或onreadystatechange事件來實現。

在Safari中加載JavaScript
因為Safari 2不支持onload或者onreadystatechange,所以只能手動通過XHR把URL讀去過來,然后再手動eval這段代碼,這就帶來了一個限制──只能加載本域的JavaScript文件。在ensure當中,eval的工作是通過HttpLibrary.globalEval()來完成的。為了讓JavaScript代碼在全局(global)上下文中eval,ensure還是使用了創建script元素的方法,并將要eval的JavaScript置于其內,最后把script元素追加到head元素內。

細心的人肯定要問,為什么HttpLibrary.globalEval()要如此設計,而非直接window.eval或者eval.call。這是因為,window.eval和eval.call都無法在IE6中實現和script標簽加載JavaScript代碼一模一樣的效果,這兩種做法的eval在IE6下仍然不是在全局上下文中執行的。搜索一下你就會發現一些相關的討論,例如jQuery就曾經使用window.execScript()來完成此項任務。不過最終大家都發現添加script元素才是最好的跨瀏覽器解決方案,所以現在的jQuery和ensure都是如此實現的了。

加載CSS
相對于加載JavaScript而言,加載CSS就簡單多了,而且方法也是類似的:在head元素內直接加入link元素就可以了。這也正是loadCSS()所完成的工作。

實際上,ensure沒有確保CSS完成加載后再執行下去。這估計是因為瀏覽器都能夠在CSS加載完成后自動應用到頁面上,因此Omar AL Zabir就認為CSS的加載順序是無關緊要的,不過假如CSS加載速度實在太慢,其實還是會影響顯示效果的。

在IE6中加載CSS
這次需要特別照顧的是IE6,而非Safari。IE6在往head元素添加link元素時,必須在window的上下文中完成,因此添加link的函數通過call調用切換了上下文。

總結
實際上動態加載JavaScript與CSS都并不難,在大多數情況下只需要向head元素追加對應的子元素就可以了,只有Safari2和IE6這兩款古老的瀏覽器是需要特殊照顧的。
官方地址
ensure

JavaScript技術多瀏覽器兼容的動態加載 JavaScript 與 CSS第1/2頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 玉匣记全文免费| 蓝眼泪简谱| 雀圣 电影| 楼南光电影| 蚀电影| 即便是爸爸也想恋爱| cctv6电影节目表| 家书1000字| 飞头魔女电影完整版免费观看| 2025八方来财微信头像| 我爱你再见演员表| 北京卫视今日播出节目表| 八年级上册英语课堂作业答案| 妻子的秘密按摩电影| 水管十大品牌排行榜前十名| 天云山传奇 电影| 中央八套电视剧| 我在碧桂园的1000天| 藏地奇兵| 五月天丁香婷婷| 《东北警察故事2》大结局| 彭丹丹主演的经典电影| 尹馨演过的三部电影| 邓家佳电影| 太子传说| 电视播放| 来自地狱| 局中局| 韩国一级黄色录像| 包天笑| 大秦帝国第一部免费看| 误杀2演员| derpixon动画在线观看| 刑事侦缉档案1演员表| 03s402| 2025年最旺财聚财壁纸| 朱丽安·摩尔| 日本电影芋虫| 削发| 下女们| 李保田最经典十部电影|