多浏览器兼容的动态加载 JavaScript 与 CSS第1/2页

时间:2024-05-13 09:20:31 

在介绍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
                           

12下一页阅读全文

标签:多浏览器,动态加载,JavaScript,CSS
0
投稿

猜你喜欢

  • laravel接管Dingo-api和默认的错误处理方式

    2023-11-21 23:29:37
  • 详解php中implode explode serialize json msgpack性能对比

    2023-09-03 18:00:19
  • 浅析Golang中的协程(goroutine)

    2024-04-29 13:05:08
  • MySQL中count(*)、count(1)和count(col)的区别汇总

    2024-01-23 07:13:43
  • python实现kNN算法

    2023-01-24 13:58:06
  • 十分钟轻松掌握dataframe数据选择

    2021-03-03 11:11:40
  • Vue + Webpack + Vue-loader学习教程之相关配置篇

    2024-04-29 13:10:40
  • python中np是做什么的

    2021-08-25 21:45:23
  • JS HTML5拖拽上传图片预览

    2024-04-22 13:03:38
  • js中int和string数据类型互相转化实例

    2024-05-02 17:25:57
  • pycharm显示远程图片的实现

    2021-03-02 13:27:39
  • js实现本地持久化存储登录注册

    2024-04-16 10:35:05
  • Python工程师面试题 与Python Web相关

    2021-11-10 13:00:48
  • MySQL中对表连接查询的简单优化教程

    2024-01-25 19:15:49
  • Python Django 封装分页成通用的模块详解

    2023-06-24 13:56:15
  • MySQL最基本的命令使用汇总

    2024-01-28 06:18:30
  • 浅谈JavaScript中promise的使用

    2024-04-16 08:55:44
  • 用玩票的心态瞎猜豆瓣的思路

    2008-08-18 21:14:00
  • Python导入模块包原理及相关注意事项

    2023-01-26 04:46:31
  • Python设计模式编程中解释器模式的简单程序示例分享

    2023-01-16 08:44:29
  • asp之家 网络编程 m.aspxhome.com