SVG灰度过滤器中的Firefox错误



我正在使用我当前正在处理的网站上的SVG过滤器。它应该使图像保持饱和,当我悬停时,它们应该返回正常的彩色状态。我使用了一个在线教程,它在Chrome,IE,Safari中效果很好,但是在Firefox中,图像没有显示出来,只是Blanc,当您悬停在它们之上时,它们突然以彩色状态显示。我尝试搜索解决方案,但是我发现的唯一类似情况是因为ID错误。

我的SVG代码:

<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>

我的CSS代码:

#thumbnails li img
{
    width: 31%;
    filter: url(filters.svg#grayscale); /* Firefox 3.5+ */
    filter: gray; /* IE6-9 */
    -webkit-filter: grayscale(1); /* Google Chrome & Safari 6+ */
    margin-bottom: 1.3%;
    margin-top: 1.3%;
}
#thumbnails img:hover 
{
    filter: none;
    -webkit-filter: grayscale(0);
}

我在Firefox中遇到的控制台错误是:

"过滤器"的解析值错误。声明删除

如果您需要额外的信息,我很乐意提供它。非常感谢。蒂莫西

用于未来的参考(因为这是一个旧问题,我不确定OP是否需要此问题...)

.svg:

<?xml version="1.0" encoding="UTF-8"?>
<svg version="1.1"
     baseProfile="full"
     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>

CSS:

.YOUR_DIV img {
    width: 260px;
    height: 190px;
     filter: grayscale(100%); /* Current draft standard */
    -webkit-filter: grayscale(100%); /* New WebKit */
    -moz-filter: grayscale(100%);
    -ms-filter: grayscale(100%); 
    -o-filter: grayscale(100%); /* Not yet supported in Gecko, Opera or IE */ 
    filter: url(PATH/TO/SVG/**filter**.svg#grayscale); /* Gecko */
    filter: gray; /* IE */
    -webkit-filter: grayscale(1); /* Old WebKit */
}
.YOUR_DIV img:hover {
    filter: none;
    -webkit-filter: grayscale(0);
}

*请确保更改CSS中过滤器的路径和名称以匹配您的文件。SVG和ID。

最新更新