我知道如何做border opacity,如何做background image opacity,但我想有一个没有边界不透明的元素,有背景图像不透明。我不想在图像编辑器中修改图像,所以我正在寻找由CSS设置的不透明度。可能吗?
在下面的CSS中,我想修改“禁用”状态,使其具有清晰的无不透明边框。请建议。。。
使用示例:this fiddle
按钮样式:
div.button, div.button:hover
{
background: none;
border: 2px solid #6C7B8B;
border-radius: 8px;
clear: none;
color: transparent;
cursor: pointer;
display: inline-block;
filter: alpha(opacity=100);
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
float: none;
height: 24px;
margin-bottom: 0px;
margin-left: 3px;
margin-right: 0px;
margin-top: 7px;
opacity: 1;
-moz-opacity: 1;
outline: none;
overflow: hidden;
padding: none;
vertical-align: top;
width: 24px;
}
点击效果:
div.button:active
{
left: 1px;
position: relative;
top: 1px;
}
禁用状态的附加样式:
div.disabled, div.disabled:hover
{
cursor: default;
filter: alpha(opacity=50);
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
opacity: 0.50;
-moz-opacity: 0.50;
}
div.disabled:active
{
left: 0px;
position: relative;
top: 0px;
}
状态的附加样式:
div.on, div.on:hover
{
border: 2px solid #007FFF;
}
最佳答案
您正处于与CSS: set background image with opacity?相同的情况-您希望有一个透明的背景,但非透明的内容(边界对其计数)。
因此,在CSS3中没有这样的background-image-opacity
,您只能构建一个透明的图像,或者将两个元素放在彼此上方,其中较低的元素包含图像(如答案所示)。
但在你的情况下,这就足以使图像黯淡。例如,这可以通过从一开始就使用透明图像来完成,但要更改底层background-color
。或者你会用
<div class="button" title="Zoom!"><img src="icon.gif" alt="glasses" /></div>
具有
div.button.disabled img { opacity: .5; }
这在语义上也更有意义。你应该远离那些内联样式。
(updated fiddle)