使用CSS盒模型中的border(边框)即可实现如下所示的三角形:

css画三角形 - 图1

实现原理:

首先来看在为元素添加border时,border的样子;假设有如下代码:

  1. <div></div>
  2. div {
  3. width: 50px;
  4. height: 50px;
  5. border: 2px solid orange;
  6. }

css画三角形 - 图2
这是我们平常使用border最普遍的情况——往往只给border一个较小的宽度(通常为1-2px);然而这样的日常用法就会容易让大家对border的形成方式产生误解,即认为元素的border是由四个矩形边框拼接而成。
然而事实并不是这样。实际上,元素的border是由三角形组合而成,为了说明这个问题,我们可以增大border的宽度,并为各border边设置不同的颜色:

  1. div {
  2. width: 50px;
  3. height: 50px;
  4. border: 40px solid;
  5. border-color: orange blue red green;
  6. }

css画三角形 - 图3
把元素的内容尺寸设置为0,会是什么样子呢

css画三角形 - 图4元素内容尺寸为0
我们将惊奇地发现,此时元素由上下左右4个三角形“拼接”而成;那么,为了实现最终的效果,即保留最下方的三角形,还应该怎么做?很简单,我们只需要把其它border边的颜色设置为白色透明色

  1. div {
  2. width: 0;
  3. height: 0;
  4. border: 40px solid;
  5. border-color: transparent transparent red;
  6. }

css画三角形 - 图5
Duang~ 最终的简单三角形就绘制出来了。同理,如果想要得到其它边上的三角形,只需要将剩余的border边颜色设置为白色或透明色即可。
不过,被“隐藏”的上border仍然占据着空间,要想使得绘制出的三角形尺寸最小化,还需要将上border的宽度设置为0(其它情况同理):

  1. div {
  2. width: 0;
  3. height: 0;
  4. border-width: 0 40px 40px;
  5. border-style: solid;
  6. border-color: transparent transparent red;
  7. }