首页 > 代码库 > 如何给不支持新特性的浏览器打补丁
如何给不支持新特性的浏览器打补丁
一个非常棒的 JavaScript 框架叫做 Modernizr(http://www.modernizr. com),用于向缺少 HTML5/CSS3特性支持的浏览器打补丁。由 Alexander Farkas编写的
“Webshims Lib”(http://afarkas.github.com/webshim/demos/)就是构建于 Moderniz和无处 不在的 jQuery之上的,它可用于插入表单补丁(也可以为其他 HTML5特性打补丁),从
而使不支持新特性的浏览器可以处理 HTML5 表单。最值得称道的一点是,它利用了 Modernizr 的加载功能,能做到只加载实际所需的补丁。如果在原生支持 HTML5 新特性
的浏览器中查看网页,则仅会给网页加入一丁点儿冗余代码。而对于老版本浏览器,虽 然它们需要加载更多的代码(因为它们本身能力不足),但通过相关 JavaScript 方法的辅
助,它们能提供基本一致的用户体验。 通过打补丁受益的不仅仅只是老版本浏览器。我们知道,现在的很多浏览器也没有完全
实现 HTML5 的表单特性。在网页中引入 Webshims Lib 可以弥补这些浏览器的缺陷。例 如在 Safari中,提交一个必填项为空的 HTML5表单时不会有任何警告信息。其实这个表
单根本不会提交,但它也没给用户任何反馈,这一点都不人性化。在页面中引入 Webshims
Lib 后,上述问题会得到弥补:
首先下载 Webshims Lib(http://github.com/aFarkas/webshim/downloads)并解压。然后将
其中的 js-webshim 文件夹复制到相应的位置。为简便起见,本例中我将其拷贝到网站的
根目录,然后在页面的 <head> 部分加入如下代码:
<script src="http://www.mamicode.com/js/jquery-1.7.1.js"></script>
<script src="http://www.mamicode.com/js-webshim/minified/extras/modernizr- custom.js"></script>
<script src="http://www.mamicode.com/js-webshim/minified/polyfiller.js"></script>
<script>
//加载补丁
$.webshims.polyfill();
</script>
分析一下这段代码。首先引入了一个本地的 jQuery库文件(可以在 www.jquery.com上下
载最新版本):
<script src="http://www.mamicode.com/js/jquery-1.7.1.js"></script>
接着,又引入了 Webshims Lib所包含的 Modernizr以及补丁相关的 JavaScript文件:
<script src="http://www.mamicode.com/js-webshim/minified/extras/modernizr-custom.js"></script>
<script src="http://www.mamicode.com/js-webshim/minified/polyfiller.js"></script>
最后,使用初始化脚本来加载所需的补丁:
<script>
//加载补丁
$.webshims.polyfill();
</script>
搞定。现在,浏览器缺失的新功能都会通过相关补丁脚本被自动追加进来了。
感谢您的阅读。如果文章对您有用,那么请轻轻点个赞,以资鼓励。
如何给不支持新特性的浏览器打补丁
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。