我正在使用我当前正在处理的网站上的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。