Modernizr.js笔记
来源:互联网 发布:淘宝怎么看行业数据 编辑:程序博客网 时间:2024/05/11 05:46
什么是Modernizr?
Modernizr 是一个用来检测浏览器功能支持情况的 JavaScript 库。 目前,通过检验浏览器对一系列测试的处理情况,Modernizr 可以检测18项 CSS3 功能以及40多项关于HTML5 的功能。 它比传统检测浏览器名称(浏览器嗅探)的方式更为可靠。 一整套测试的执行时间仅需几微秒。 此外,Modernizr 网站通过定制脚本只对你感兴趣的元素进行检测,从而实现效率优化。
下载 Modernizr
与其它 JavaScript 库相同的是,Modernizr 可提供 development 和 production 版本。 与大多数库相比,唯一的不同之处是,空格和注释已经从 production 版本中删除了,这样可以减少下载量的大小。 Modernizr 采取了不同的方法。 development 版本在某种意义上可称为是“厨房中的水槽”—它几乎包含了一切。 production 版本只包含了你选择的那些元素,这样能够显著降低下载量。 在很多情况下,production 版本可以缩小为development版本大小的二十分之一。
重点:
<head> 的最后三行应该如下所示:
</style>
<script src="js/modernizr.js"></script>
</head>
在html标签中添加no-js的class,当支持javascript的浏览器启动时,会动态地删除这个no-js的class。并且会在html标签中添加当前浏览器所支持的元素同名class。
如图所示。
你可以在浏览器中检查元素时看到html标签中增加的类,而在本地源代码中并无改动。
例如,在页面中的img标签,如若浏览器不支持阴影,则.no-boxshadow img { border-right: #8A8A8A 2px solid; border-bottom: #8A8A8A 2px solid; }将会发挥作用。也就是说,你可以看到Modernizr使用boxshadow 和 csscolumns 分别表明了对box-shadow 属性和多栏布局的支持。 因此,你可以使用no-boxshadow 和 no-csscolumns 类为不支持这些功能的浏览器创建特殊的样式规则。
一句忠告
Modernizr 是一个强大而有用的工具,但是这并不意味着你就应该使用它。 并不是在所有情形下均必须使用 Modernizr 给浏览器提供多种样式。 如果你主要关注的对象是 Internet Explorer,那么考虑使用IE conditional comments。 你也可以使用CSS层叠覆盖一些样式。 例如,先使用hexadecimal color,然后使用 rgba() 或 hsla() 覆盖它。 旧版本的浏览器会使用第一个值并且忽略第二个值。
Modernizr 真正地变成现实是当它与 polyfills 和其它 JavaScript 相结合的时候。但是记住,通常很容易创建属于你自己的适合支持功能的测试。例如,下面就是你测试某个浏览器是否支持 required 属性的全部代码(代码位于required_nomodernizr.html 中):
var elem = document.createElement('input');
if (typeof elem.required != 'boolean'){
// required is not supported
}
阅读全文
0 0
- Modernizr.js笔记
- Modernizr.js入门指南
- Modernizr.js-简
- Modernizr.js-使用
- Modernizr.js 介绍
- Modernizr.js和yepnode.js
- Modernizr.js介绍与使用
- Modernizr
- Modernizr
- modernizr
- Modernizr
- js库Modernizr的介绍和使用
- js库Modernizr的介绍和使用
- 前端开发HTML5和CSS3的强有力前端js检测类库:js框架Modernizr
- Modernizr使用
- Modernizr使用指南
- 什么是Modernizr?
- Modernizr, html5shiv, ie7.js, and CSS3 Pie. 该用哪个,什么时候用
- python中字符串前加u,r,b的含义
- Python日志打印
- Hibernate的配置
- [Leetcode][python]Reverse Linked List/Reverse Linked List II
- java之动态代理
- Modernizr.js笔记
- 内部类
- OkHttp3源码解析05-连接池
- java 获取当月的第一天和最后一天
- 三周一次课(10月30日)
- Unity之AssetBundle原理全解
- dagger2学习笔记
- 【2017-10-30】这是一个新的Flag
- 万圣节动画-canvas像素点