modernizr检查灰度过滤器IE 10

时间:2013-04-22 15:05:02

标签: jquery filter modernizr

IE 10不支持DX过滤器(yeaaaay)我目前正在使用$.browser来检测IE 10并实施svg解决方案。

然而,$.browser已被弃用,将被删除或已被删除(Yeaaaay再次!!!!)。那么,在这种情况下,现代化者对$.browser的替代方案是什么?

filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#grayscale"); /* Firefox 10+ */
filter: gray; /* IE6-9 */
-webkit-filter: grayscale(100%); /* Chrome 19+ & Safari 6+ */
-webkit-transition: all .6s ease; /* Fade to color for Chrome and Safari */
-webkit-backface-visibility: hidden; /* Fix for transition flickering */

我尝试了if (Modernizr.css_filters),但这不起作用

1 个答案:

答案 0 :(得分:5)

你应该可以使用:

Modernizr.cssfilters

Modernizr.svgfilters

对于定位IE10,我认为.svgfilters是你应该使用的那个。这是一个可搜索的Modernizr测试数据库:http://www.browserleaks.com/modernizr#filter

这些是源文件:

CSS过滤器测试:https://github.com/Modernizr/Modernizr/blob/master/feature-detects/css/filters.js

SVG过滤器测试:https://github.com/Modernizr/Modernizr/blob/master/feature-detects/svg/filters.js