Rya*_*ing 5 css firefox svg css-transitions svg-filters
我试图在悬停时将图像从50%灰度滤镜转换为无滤镜状态.
但转换在Firefox中不起作用.是否有可能只使用css在firefox中运行转换?
img {
filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'saturate\' values=\'0.5\'/></filter></svg>#grayscale"); /* Firefox 3.5+ */
filter: gray alpha(opacity=50); /* IE6-9 */
-webkit-filter: grayscale(50%); /* Chrome 19+ & Safari 6+ */
-webkit-transition: all .6s ease; /* Fade to color for Chrome and Safari */
-moz-transition: all .6s ease;
-ms-transition: all .6s ease;
transition: all .6s ease;
-webkit-backface-visibility: hidden; /* Fix for transition flickering */
}
img:hover {
filter: none;
-webkit-filter: grayscale(0);
}
Run Code Online (Sandbox Code Playgroud)
因为标准过滤器语法是 url,所以它不适合转换。Gecko 必须实现正在构建的Filter Effects规范的速记部分才能使其工作。
同时,您可以使用 SVG 动画来完成此操作,而不能仅通过 CSS。