什么是最好的方法(如果有),使图像显示“灰色”与CSS(即,没有加载一个单独的,灰色的图像版本)?
我的上下文是,我在一个表中有行,在最右边的单元格中都有按钮,一些行需要看起来比其他行更轻。所以我可以让字体更轻,当然,我也想让图像更轻,而不必管理每个图像的两个版本。
什么是最好的方法(如果有),使图像显示“灰色”与CSS(即,没有加载一个单独的,灰色的图像版本)?
我的上下文是,我在一个表中有行,在最右边的单元格中都有按钮,一些行需要看起来比其他行更轻。所以我可以让字体更轻,当然,我也想让图像更轻,而不必管理每个图像的两个版本。
当前回答
你可以在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大于零,你把它放在你的图像之前,矩形的默认位置将是你的图像的左上角。应该工作。
其他回答
最好支持所有浏览器:
img.lessOpacity {
opacity: 0.4;
filter: alpha(opacity=40);
zoom: 1; /* needed to trigger "hasLayout" in IE if no width or height is set */
}
使用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: grayscale(100%);
@关键帧消色{ 0% {} 25% {} 75%{滤镜:灰度(100%);} 100%{滤镜:灰度(100%);} } p { 字体大小:5 em; 颜色:黄色; 动画:消色差2s缓和无限交替; } p: first-of-type { background - color: dodgerblue; } < p > ⚡Bzzzt ! < / p > < p > ⚡Bzzzt ! < / p >
“用灰色填满。”
filter: contrast(0%);
@keyframes gray-filling { 0% {} 25% {} 50% {filter: contrast(0%);} 60% {filter: contrast(0%);} 70% {filter: contrast(0%) brightness(0%) invert(100%);} 80% {filter: contrast(0%) brightness(0%) invert(100%);} 90% {filter: contrast(0%) brightness(0%);} 100% {filter: contrast(0%) brightness(0%);} } p { font-size: 5em; color: yellow; animation: gray-filling 5s ease-out infinite alternate; } p:first-of-type { background-color: dodgerblue; } <p> ⚡ Bzzzt! </p> <p> ⚡ Bzzzt! </p>
有用的笔记
CSS3滤镜灰度和饱和度有什么区别? https://www.w3.org/TR/filter-effects-1
你可以在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大于零,你把它放在你的图像之前,矩形的默认位置将是你的图像的左上角。应该工作。