2025-03-23 06:00:03

灰色的图像与CSS?

什么是最好的方法(如果有),使图像显示“灰色”与CSS(即,没有加载一个单独的,灰色的图像版本)?

我的上下文是,我在一个表中有行,在最右边的单元格中都有按钮,一些行需要看起来比其他行更轻。所以我可以让字体更轻,当然,我也想让图像更轻,而不必管理每个图像的两个版本。


当前回答

使用CSS3过滤器属性:

img {
    -webkit-filter: grayscale(100%);
       -moz-filter: grayscale(100%);
         -o-filter: grayscale(100%);
        -ms-filter: grayscale(100%);
            filter: grayscale(100%); 
}

浏览器支持相当不错,https://caniuse.com/css-filters。

其他回答

下面是一个让你设置背景颜色的例子。如果你不想使用浮动,那么你可能需要手动设置宽度和高度。但这也取决于CSS/HTML。

<style>
#color {
  background-color: red;
  float: left;
}#opacity    {
    opacity : 0.4;
    filter: alpha(opacity=40); 
}
</style>

<div id="color">
  <div id="opacity">
    <img src="image.jpg" />
  </div>
</div>

考虑filter:expression是微软对CSS的扩展,所以它只能在Internet Explorer中工作。如果你想让它变灰,我建议你使用javascript将它的不透明度设置为50%。

http://lyxus.net/mv是一个很好的开始,因为它讨论了不透明度 脚本,适用于Firefox, Safari, KHTML, Internet Explorer和CSS3浏览器。

你可能还想给它一个灰色边框。

使用CSS3过滤器属性:

img {
    -webkit-filter: grayscale(100%);
       -moz-filter: grayscale(100%);
         -o-filter: grayscale(100%);
        -ms-filter: grayscale(100%);
            filter: grayscale(100%); 
}

浏览器支持相当不错,https://caniuse.com/css-filters。

你可以在css中使用rgba()来定义颜色,而不是rgb()。是这样的: Style ='background-color: rgba(128,128,128,0.7);

给你相同的颜色rgb(128,128,128),但与70%的不透明度,所以后面的东西只显示通过30%。CSS3,但自2008年以来,它在大多数浏览器中都有效。对不起,我不知道#rrggbb语法。玩弄数字——你可以用白色来洗去,用灰色来阴影,用任何你想稀释的东西。

好的,所以你做了一个半透明灰色(或任何颜色)的矩形,并把它放在你的图像的顶部,可能与position:absolute和z-index大于零,你把它放在你的图像之前,矩形的默认位置将是你的图像的左上角。应该工作。

如果您不介意使用一点JavaScript, jQuery的fadeTo()在我尝试过的每种浏览器中都能很好地工作。

jQuery(selector).fadeTo(speed, opacity);