效果展示如下:
那么为什么将border的三个边设置为transparent透明以后能生产一个三角形呢?接下来我们一步步解析。
我们来看一个平时使用的border例子:
这是我们平常使用border最普遍的情况——往往只给border一个较小的宽度(通常为1-2px);然而这样的日常用法就会容易让大家对border的形成方式产生误解,即认为元素的border是由四个矩形边框拼接而成。
然而事实并不是这样。实际上,元素的border是由三角形(准确说也是等边梯形)组合而成,为了说明这个问题,我们可以增大border的宽度,并为各border边设置不同的颜色:
效果图:
我们可以看到明显的四条边不是长方形,而是梯形,很像相框的四条边。
梯形的底是div对应的height或者width,梯形的高是对应border的宽度,梯形的顶边长度取决于div的内部空间。
我们进一步把div的高宽都改为0,梯形的顶边宽度变成了0,则可以得到对应的三角形了。
效果图:
此时元素由上下左右4个三角形“拼接”而成;那么,为了实现最终的效果,即保留最s上方的三角形,还应该怎么做?很简单,我们只需要把其它border边的颜色设置为白色或透明色:
效果图:
最终的简单三角形就绘制出来了。同理,如果想要得到其它边上的三角形,只需要将剩余的border边颜色设置为白色或透明色即可。
不过,被“隐藏”的上border仍然占据着空间,要想使得绘制出的三角形尺寸最小化,还需要将上border的宽度设置为0(其它情况同理):
我们的思路是使用border边框来实现三角形的样式,因为border的边框是由四个三角形组成的。
请点击输入图片描述
首先我们创建一个带边框的div:
具体代码实现如下:
width: 40px
height: 40px
border-width: 40px
border-style: solid
border-color: red green blue brown
请点击输入图片描述
然后我们将内部DIV的宽高设置为0:
width: 20px
height: 20px
border-width: 10px
border-style: solid
border-color: red green blue brown
请点击输入图片描述
将其他的三个边框给取消点:
width: 0
height: 0
border-width: 40px
border-style: solid
border-color: red transparent transparent transparent
请点击输入图片描述
利用更改border的边框,我们可以随意控制写出我们想要的三角形,通过控制边框的大小来实现三角形的大小,通过控制边框的位置来改变三角形的位置。
请点击输入图片描述
6
使用上面的方式实现三角形有一个问题就是,三角形的方位不太好控制,但是使用其他的方式依然会面临这样的问题。
请点击输入图片描述
你好,我这里用CSS实现了三种带边框三角,效果分别如图:
实例代码如下,根据你个人的情况调整代码吧:
<!DOCTYPE html><html lang="en">
<head>
<meta charset="UTF-8">
<title>Arrow</title>
</head>
<body>
<style>
/* scale */
.arrow,
.arrow:after{
position: relative
display: inline-block
width: 0
height: 0
border-top: 0
border-left: 30px dotted transparent
border-right: 30px dotted transparent
border-bottom: 30px dashed #000
}
.arrow:after {
position: absolute
top: 0
content: ''
transform: translateX(-50%) scale(.8)
border-bottom: 30px dashed #fff
}
/* width & height */
.arrow1,
.arrow1:after {
position: relative
display: inline-block
width: 0
height: 0
border-top: 0
border-left: 30px dotted transparent
border-right: 30px dotted transparent
border-bottom: 30px dashed #000
}
.arrow1:after {
position: absolute
left: -26px
top: 2px
content: ''
width: 0
height: 0
border-top: 0
border-left: 26px dotted transparent
border-right: 26px dotted transparent
border-bottom: 26px dashed #fff
}
/* border & after */
.arrow2 {
position: relative
display: inline-block
width: 28px
height: 28px
border: 0
border-top: 2px solid #000
border-right: 2px solid #000
-webkit-transform: translate(7px, 14px) rotate(-45deg)
-ms-transform: translate(7px, 14px) rotate(-45deg)
-o-transform: translate(7px, 14px) rotate(-45deg)
transform: translate(7px, 14px) rotate(-45deg)
}
.arrow2:after {
position: absolute
left: 0
top: -2px
width: 42px
height: 2px
content: ''
border-radius: 2px
background-color: #000
-webkit-transform-origin: left top
-moz-transform-origin: left top
-ms-transform-origin: left top
-o-transform-origin: left top
transform-origin: left top
-webkit-transform: rotate(45deg)
-ms-transform: rotate(45deg)
-o-transform: rotate(45deg)
transform: rotate(45deg)
}
</style>
<span class="arrow"></span>
<span class="arrow1"></span>
<span class="arrow2"></span>
</body>
</html>
希望能帮到你,如有疑问请追问,望采纳~