大连仟亿科技
客服中心
  • 电话
  • 电话咨询:0411-39943997
  • 手机
  • 手机咨询:15840979770
    手机咨询:13889672791
网络营销 >更多
您现在的位置:仟亿科技 > 新闻中心 > 常见问题

用JS检测浏览器对CSS3特性是否支持

作者:billionnet 发布于:2012/10/12 17:02:49 点击量:

 

网站开发项目中需要快速检测浏览器是否支持某CSS3特性,比如检测是否支持“transform”,然后我的布局会有两种完全不同的版式。

当然除开本文介绍的这种快速方法,还有一种更有名和更通用的方法,那就是modernizr,运行脚本之后它会在html的class上加上浏览器支持的所有特性的列表。

优点:

  • js是可配置的,不需要的特性检测可以在配置脚本中去掉
  • 基于特性检测
  • js库简单好用

modernizr

除此之外还有一种不太好的方法,那就是判断浏览器的UA,不好的原因是UA可能会伪造,而且版本判断繁琐,还有不稳定。

优点:性能可能是最优的

后面就是本文介绍的这个方法,我写了一个函数快速检测是否浏览器支持某CSS特性,适合的场景是快速需要知道浏览器是否支持某一个CSS特性(而不是好几个)。

优点:

  • 性能不错
  • 通用性强
  • 适合检测单个CSS特性
var supports = (function() {
 var div = document.createElement('div'),
 vendors = 'Khtml Ms O Moz Webkit'.split(' '),
 len = vendors.length;
 return function(prop) {
 if ( prop in div.style ) return true;
 prop = prop.replace(/^[a-z]/, function(val) {
 return val.toUpperCase();
 });
 while(len--) {
 if ( vendors[len] + prop in div.style ) {
 // browser supports box-shadow. Do what you need.
 // Or use a bang (!) to test if the browser doesn't.
 return true;
 }
 }
 return false;
 };
})();
if ( supports('textShadow') ) {
 document.documentElement.className += ' textShadow';
}

这就是终终代码,原理是:

1.创建一个div,然后可以获得div.style,这是它所支持的属性的数组列表。

div.style

2.检查text是否包含在数组中,如果是,直接返回true。

3.检查各种前缀,比如Webkit加上text,即webkitTransition,如果包含在style中,返回true。

4.值得注意的是在CSS中属性名为:-webkit-transition,但是在DOM的style中 ,却是对应webkitTransition。我也不知道为什么会这样。



分享到:


评论加载中...
内容:
评论者: 验证码:
  

Copyright@ 2011-2017 版权所有:大连仟亿科技有限公司 辽ICP备11013762-1号   google网站地图   百度网站地图   网站地图

公司地址:大连市沙河口区中山路692号辰熙星海国际2215 客服电话:0411-39943997 QQ:2088827823 42286563

法律声明:未经许可,任何模仿本站模板、转载本站内容等行为者,本站保留追究其法律责任的权利! 隐私权政策声明