火狐浏览器中的 SVG 滤镜过渡



我正在尝试将图像从 50% 灰度滤镜转换为悬停时的无滤镜状态。

但是,这种过渡在火狐中不起作用。是否可以仅使用 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);
}

由于标准筛选器语法是 url,因此不适合转换。Gecko必须实现正在建设中的滤镜效果规范的速记部分才能正常工作。

同时,您可以使用SVG动画执行此操作,但不能仅通过CSS执行此操作。

相关内容

  • 没有找到相关文章

最新更新