HTML之CSS画三角形原理

注:本文转自pengjunlee
   原文地址:(https://blog.youkuaiyun.com/pengjunlee/article/details/53002553)
在进行WEB应用开发的过程中,我们经常会需要使用到三角形图标,例如下面这个下拉选择控件右侧的收缩箭头。

又或者像下面这种情形。

搜索网络之后发现三角形可以通过以下CSS代码实现:
  1. #triangle_bottom{  
  2. height:0px;  
  3. width:0px;  
  4. border-left:20px solid transparent;  
  5. border-right:20px solid transparent ;  
  6. border-bottom:20px solid #9E9E9E ;  
  7. }  
#triangle_bottom{
height:0px;
width:0px;
border-left:20px solid transparent;
border-right:20px solid transparent ;
border-bottom:20px solid #9E9E9E ;
}
那么,其内部到底是如何实现的呢?接下来是我学习CSS画三角形原理的一点小总结。
其实使用CSS代码绘制三角形,只是对盒子模型中的”border”属性的简单应用。盒子模型将HTML元素划分为内容(Content)、填充(Padding)、边框(Border)和边界(Margin)四部分,参照下图。

为了能更好的看清Border的四条边界的真实形状,我们为Border的四条边设置上不同的颜色。
  1. border-left:red;  
  2. border-top:blue;  
  3. border-right:green;  
  4. border-bottom:yellow;  
border-left:red;
border-top:blue;
border-right:green;
border-bottom:yellow;

不难看出,当Border的四条边宽度相同时,每条边均为等腰梯形。
为四条边设置各不相同的宽度,其各边的形状改变为如下图所示。
  1. border-left:20px red;  
  2. border-top:10px blue;  
  3. border-right:30px green;  
  4. border-bottom:40px yellow;  
border-left:20px red;
border-top:10px blue;
border-right:30px green;
border-bottom:40px yellow;

删除底部一条边后,其相邻边界的形状改变如下。
  1. border-bottom:0px;  
border-bottom:0px;

由此我们不难得出CSS画三角形所需的第一条结论:每条边(以黄色边为例)与其邻边所成夹角A,tanA=n/m(n,m分别为自己和邻边的宽度),当邻边宽度为0px时,A角大小为90°。

接下来我们将盒子模型中的内容(Content)和填充(Padding)都设置为0px,四条边的宽度相同时如下图所示。

四条边宽度不同时,各边形状如下图。

当border-top宽度为0px时,其它三边形状如下图。

再将上图中的左侧红色和右侧绿色三角形的颜色设置为透明(transparent),其最终形状如下图。

由此我们可以得出CSS画三角形所需的第二条结论: 当盒子模型中的内容(Content)+填充(Padding)的大小为0px时,Border边的形状将由梯形变为三角形。

有了以上两条结论,我们就可以通过控制Border各条边的宽度和设置透明色来轻松画出各种角度的三角形了。以画向上的底角45°的等腰三角形为例,由于tan(45°)=1,我们需将border-bottom、border-left、border-right三者设置为相等的宽度,并将border-left和border-right设置为透明色,代码如下:
  1. #triangle_bottom{  
  2. height:0px;  
  3. width:0px;  
  4. border-left:20px solid transparent;  
  5. border-right:20px solid transparent ;  
  6. border-bottom:20px solid #FF9800;  
  7. }  
#triangle_bottom{
height:0px;
width:0px;
border-left:20px solid transparent;
border-right:20px solid transparent ;
border-bottom:20px solid #FF9800;
}
其画出的三角形效果如下:

其它三个朝向的三角形画法依此类推,四个朝向的三角形的完整代码如下:
  1. <!DOCTYPE HTML>  
  2. <HTML>  
  3. <head>  
  4. <style type=“text/css”>  
  5. .triangle_left{  
  6.     width: 0;  
  7.     height: 0;  
  8.     border-left: 50px solid red;  
  9.     border-top: 50px solid transparent;  
  10.     border-bottom: 50px solid transparent;  
  11.   
  12. }  
  13. .triangle_top{  
  14.     width: 0;  
  15.     height: 0;  
  16.     border-top: 50px solid blue;  
  17.     border-right: 50px solid transparent;  
  18.     border-left: 50px solid transparent;  
  19. }  
  20. .triangle_right{  
  21.     width: 0;  
  22.     height: 0;  
  23.     border-right: 50px solid green;  
  24.     border-top: 50px solid transparent;  
  25.     border-bottom: 50px solid transparent;  
  26. }  
  27. .triangle_bottom{  
  28.     width: 0;  
  29.     height: 0;  
  30.     border-bottom: 50px solid yellow;  
  31.     border-right: 50px solid transparent;  
  32.     border-left: 50px solid transparent;  
  33. }  
  34. </style>  
  35. </head>  
  36. <body>  
  37. <div class=“triangle_left”></div>  
  38. <div class=“triangle_top”></div>  
  39. <div class=“triangle_right”></div>  
  40. <div class=“triangle_bottom”></div>  
  41. </body>  
  42. </HTML>  
<!DOCTYPE HTML>
<HTML>
<head>
<style type="text/css">
.triangle_left{
    width: 0;
    height: 0;
    border-left: 50px solid red;
    border-top: 50px solid transparent;
    border-bottom: 50px solid transparent;

}
.triangle_top{
    width: 0;
    height: 0;
    border-top: 50px solid blue;
    border-right: 50px solid transparent;
    border-left: 50px solid transparent;
}
.triangle_right{
    width: 0;
    height: 0;
    border-right: 50px solid green;
    border-top: 50px solid transparent;
    border-bottom: 50px solid transparent;
}
.triangle_bottom{
    width: 0;
    height: 0;
    border-bottom: 50px solid yellow;
    border-right: 50px solid transparent;
    border-left: 50px solid transparent;
}
</style>
</head>
<body>
<div class="triangle_left"></div>
<div class="triangle_top"></div>
<div class="triangle_right"></div>
<div class="triangle_bottom"></div>
</body>
</HTML>
效果如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值