ensure({ html: "popup.html", javascript: "popup.js", css: "popup.css" }, function() { Popup.show("hello world"); } ); 在這段代碼中,ensure首先會確保popup " /> 在线欧美免费人成视频,亚洲AV色香蕉一区二区9255,中国农民真实bbwbbw

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

多瀏覽器兼容的動態(tài)加載 JavaScript 與 CSS第1/2頁

在介紹ensure內(nèi)部的實現(xiàn)之前,讓我們先來看看其功能:

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

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

加載JavaScript
在ensure當(dāng)中,加載JavaScript分兩種情況來執(zhí)行,也就是Safari與非Safari這兩種情況。

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

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

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

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

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

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

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

JavaScript技術(shù)多瀏覽器兼容的動態(tài)加載 JavaScript 與 CSS第1/2頁,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 久久a级片| 日韩国产精品欧美一区二区 | caoporn 免费视频 | 小便japanesewctv| 巨爆乳中文字幕爆乳区 | 国产成人啪精品视频免费网 | 欧美最猛12teevideos | 国产女高清在线看免费观看 | 午夜精品久久久久久影视riav | 亚洲欧美精品无码大片在线观看 | 亚洲精品天堂无码中文字幕影院 | 亚色九九九全国免费视频 | 午夜国产精品免费观看 | 又长又大又粗又硬3p免费视频 | 不良网站进入窗口软件下载免费 | 国产精品亚洲AV毛片一区二区三区 | 国产精品99re6热在线播放 | 日韩中文亚洲欧美视频二 | 亚洲风情无码免费视频 | 永久免费无码AV国产网站 | 欧美高清videos 360p | 国内精品乱码卡一卡2卡三卡新区 | 黑丝美女被人操 | 97色伦97色伦国产 | 女的把腿张开男的往里面插 | 2021国产精品久久久久精品免费网 | 男人的天堂色 | 69久久国产精品热88人妻 | 成人精品视频在线观看 | 国精产品砖一区二区三区糖心 | 亚洲视频免费看 | 国内精品久久久久久久999下 | 闺蜜扒开我尿口使劲揉 | 好男人好资源在线观看免费视频 | 飘雪在线观看免费高清完整版韩国 | 午夜理伦大片一级 | 中文字幕无线观看不卡网站 | 国产亚洲精品首页在线播放 | 啊叫大点声欠CAO的SAO贷 | 韩国伦理三级 | 国产精品一区二区人妻无码 |