我知道如何做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

10-05 20:46
查看更多