是否可以在半透明背景上制作透明正方形?

Is it possible to make a transparent square on a semi-transparent background?

我的目标是实现类似于 的目标。
此示例图像使用 4 个半透明的黑色方块,分别位于右、左、上和下,以模拟我想要的效果

使用看起来有点像这样的代码:

.wrapper {
  position: relative;
  width: 400px;
  height: 200px;
}

.overlay {
  position: absolute;
  background-color: #0005;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}

.transparent-box {
  background-color: #fff0;
  position: absolute;
  top: 50px;
  left: 50px;
  width: 100px;
  height: 80px;
}
<!DOCTYPE html>
<html>
    <body>
      <div class="wrapper">
        <img src="https://picsum.photos/400/200" alt="">
        <div class="overlay">
          <div class="transparent-box"></div>
        </div>
      </div>
    </body>
</html>

我希望能够在使用一个元素作为背景和一个元素制作“window”的同时获得这种效果,这样例如添加圆角和类似的样式可以更容易地完成。
我试过混合模式,但我不确定它是否不支持混合模式,或者我只是设置错误。

一切都很好,除了颜色。我只是更改了背景,仅此而已。

希望这就是你想要的

.wrapper {
  position: relative;
  width: 400px;
  height: 200px;
}
.overlay {
  background-color: #0000003b;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.transparent-box {
  background-color: #ffffff78;
  position: absolute;
  top: 4rem;
  left: 50px;
  width: 100px;
  height: 80px;
}
<div class="wrapper">
  <img src="https://picsum.photos/400/200" alt="">
  <div class="overlay">
    <div class="transparent-box"></div>
  </div>
</div>

获得相同效果的一个好技巧是在叠加层上使用 box-shadow:

.overlay {
    box-shadow: 0px 0px 1px 100vmax rgba(0,0,0,0.5);
}

在这种情况下,100vmax 会填满整个页面。

  • 如果您更改 transparent-box (div) 的不透明度并设置 颜色为白色,你会得到你展示的半透明效果 在你的例子中 link.

//css of transparent-box link 编辑如下

        .transparent-box {
          background-color: white;
          opacity: 0.6;
          position: left;
          top: 50px;
          left: 50px;
          width: 100px;
          height: 80px;
        }

  • 如果你想要在正常图片周围和中间有阴影,你 需要使用阴影框:
    .transparent-box {
        opacity: 0.9;
        position: absolute;
        top: 50px;
        left: 50px;
        width: 100px;
        height: 80px;
        box-shadow: 0 0 0 100pc rgba(0, 0, 0, .8);
    }

您可以使用两张背景固定的图像 属性 来创建类似的效果。 检查这个 fiddle link jsfiddle

  $(".transparent-box").draggable();
.overlay {
  height: 300px;
  width: 300px;
  background-image: linear-gradient(0deg, #464646fc, #383333ab), url('https://via.placeholder.com/300/0000FF/808080%20?Text=Digital.com');
  background-repeat: no-repeat;
  background-attachment: fixed;
  position: relative;
}

.transparent-box {
  height: 30%;
  width: 30%;
  background-image: url('https://via.placeholder.com/300/0000FF/808080%20?Text=Digital.com');
  background-repeat: no-repeat;
  background-attachment: fixed;
  position: absolute;
}
<html>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.4/jquery-ui.min.js"></script>

<body>
    <div class="overlay">
      <div class="transparent-box"></div>
    </div>
</body>

</html>