CSS实现自然的带三角的气泡

3,327 阅读2分钟

最近视觉给的稿子上有个气泡,上面还有个小三角,这个可难不倒我,直接手敲一个div,再加一个伪元素 ::after 设置绝对定位,然后 transform: rotate(45deg),简直完美,再检查下,还有阴影啊,不难,我直接就是 box-shadow: 0 0 5px rgba(0, 0, 0, .3);,然后三角直接加个border蒙混过关

.box-shadow {
  position: relative;
  width: 200px;
  height: 200px;
  margin: 50px auto;
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 0 5px rgba(0, 0, 0, .3);
  padding: 20px;
}
.box-shadow::before{
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  transform: rotate(45deg);
  top: -7px;
  left: 50px;
  background: #ffffff;
  border-top: 1px solid rgba(0, 0, 0, .3);
  border-left: 1px solid rgba(0, 0, 0, .3);
}

结果视觉一眼就看到了说你这个不行,边框太明显了,那试试加个阴影吧

这阴影下边那块怎么设置都搞不定,陷入沉思。这时候,同事拍一拍我的肩膀,跟我说你这个没用,我这个有用,只见他就是一鞭,两鞭,三鞭,两分多钟以后写好了。

我一看,奥,原来是用了drop-shadow写的

.drop-shadow{
  position: relative;
  width: 200px;
  height: 200px;
  margin: 50px auto;
  border-radius: 12px;
  background: #ffffff;
  filter: drop-shadow(0 0 5px rgba(0, 0, 0, .3));
  padding: 20px;
}
.drop-shadow::before{
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  border: 10px solid transparent;
  border-bottom-color: #ffffff;
  top: -20px;
  left: 50px;
}

然后关于 box-shadowdrop-shadow的区别就很明显了, box-shadow是盒子的投影,它只是盒子的阴影,平常可能没啥发现,但是如果盒子内部是透明的,盒子阴影依旧不会穿透。 drop-shadow才是符合真实世界的投影,只有非透明的颜色才有投影,透明的颜色会直接投过去,我们把上面两个盒子的背景色去掉

学到了,学到了,今天的摸鱼工作没有白做。