CSS绘制箭头
2018-09-07 本文已影响1006人
夏知更
实际需求中,很多时候都会有箭头的情况,只不过一开始总是喜欢找别人写好的,随着需求的增加,很难通过修改来满足需求,所以理解原理自己动手才是万难的根本解决办法。
一、绘制三角
容器:
<div class="container">
</div>
样式:
.container{
width: 0;
height: 0;
border: 50px solid;
border-color: red yellow green blue;
}
效果如图:
data:image/s3,"s3://crabby-images/49bf5/49bf5c144ea893c9f8bf0164d752b5656a9dbc14" alt=""
利用border绘制了四个三角组成的矩形,现在要绘制三角形,只需要让其他任意三个三角形变为透明即可。
修改代码:
border-color: red transparent transparent transparent;
data:image/s3,"s3://crabby-images/f8889/f88891147d2e5b1b4e59a1c5050355b441f4b2e6" alt=""
二、绘制箭头
利用三角绘制箭头,只需要再绘制一个和此三角大小相同,方向相同的三角,颜色和背景颜色一样,覆盖在此三角上面,通过少量的位移形成箭头。
data:image/s3,"s3://crabby-images/37ff1/37ff1df5d60a68c2dc779303265ba82ed6e3cafa" alt=""
.container{
width: 0;
height: 0;
border: 50px solid;
border-color: red transparent transparent transparent;
position: relative;
}
.container::after{
content: '';
position: absolute;
top: -55px;
left: -50px;
border: 50px solid;
border-color: white transparent transparent transparent;
}
data:image/s3,"s3://crabby-images/aa32b/aa32bbd34297bd67c313244183cfcdc59c309df6" alt=""
这是一个基本的完成箭头,只能满足最简单的场景,现在对它做一点基本的扩展。
三、扩展
data:image/s3,"s3://crabby-images/7879e/7879e8a27fa2ec09f2d71a8cb991309a322c38d5" alt=""
现在想要做一个箭头叠加的效果,像这样的下拉图标,刚好可以学以致用。
html设置容器:
<div class="box">
<div class="arrow-container">
<div class="arrow-up"></div>
<div class="arrow-down"></div>
</div>
</div>
外层box:
.box{
width:160px;
height: 20px;
border: 1px solid #dddddd;
position: relative;
}
内层箭头container居中:
.arrow-container{
width: 30px;
position: absolute;
left: 50%;
margin-left: -15px;
}
两个箭头叠加:
.arrow-up{
position: relative;
z-index: 100;
}
.arrow-up::before{
content: '';
position: absolute;
border-left: 12px solid;
border-top:10px solid;
border-right: 12px solid;
border-bottom: 10px solid;
border-color: #2dacfd transparent transparent transparent;
}
.arrow-up::after{
content: '';
position: absolute;
border-left: 12px solid;
border-top:10px solid;
border-right: 12px solid;
border-bottom: 10px solid;
border-color: white transparent transparent transparent;
left: 0;
top: -2px;
}
.arrow-down{
position: relative;
top:8px;
}
.arrow-down::before{
content: '';
position: absolute;
border-left: 12px solid;
border-top:10px solid;
border-right: 12px solid;
border-bottom: 10px solid;
border-color: #2dacfd transparent transparent transparent;
}
.arrow-down::after{
content: '';
position: absolute;
border-left: 12px solid;
border-top:10px solid;
border-right: 12px solid;
border-bottom: 10px solid;
border-color: white transparent transparent transparent;
left: 0;
top: -2px;
}
data:image/s3,"s3://crabby-images/a2585/a25859184c8b46924a8e96567c3eebbc6e246f37" alt=""
注意细节:
- 以前设置border时
border: 10px solid;
是个正方形,箭头打开的角度是90度,看起来很怪异,为了更好看一定,border分开设置,左右border设置大一点,可以保证打开的角度更大更平缓。 - 箭头的叠加都是每个箭头有2个三角叠加形成的效果,然后两个箭头通过定位来改变位置,当两个箭头靠的比较近时,下面箭头的透明三角色块会挡住上面箭头的底部,为了解决这个问题,需要给箭头设置
z-index
使其显示在上层。
综合修改之后:
data:image/s3,"s3://crabby-images/8811f/8811f344deb4b5ccda75b1161ed45ef55c29eb01" alt=""
四、扩展实践
data:image/s3,"s3://crabby-images/0e7ac/0e7ac4da4b5f07a2f94fe6f5fbefc3c0a408a427" alt=""
data:image/s3,"s3://crabby-images/9ccf3/9ccf3a579304cf767f31c0489901cab41216442c" alt=""