最近视觉给的稿子上有个气泡,上面还有个小三角,这个可难不倒我,直接手敲一个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-shadow
和 drop-shadow
的区别就很明显了, box-shadow
是盒子的投影,它只是盒子的阴影,平常可能没啥发现,但是如果盒子内部是透明的,盒子阴影依旧不会穿透。 drop-shadow
才是符合真实世界的投影,只有非透明的颜色才有投影,透明的颜色会直接投过去,我们把上面两个盒子的背景色去掉
学到了,学到了,今天的摸鱼工作没有白做。