CSS绘制三角形—border法
1. 实现一个简单的三角形
使用CSS盒模型中的border(边框)即可实现如下所示的三角形:

实现原理:
首先来看在为元素添加border时,border的样子;假设有如下代码:
<div></div>
div {
    width: 50px;
    height: 50px;
    border: 2px solid orange;
}
效果图:

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

既然如此,那么更进一步,把元素的内容尺寸设置为0会发生什么情况呢?
div {
    width: 0;
    height: 0;
    border: 40px solid;
    border-color: orange blue red green;
}
效果图:

我们将惊奇地发现,此时元素由上下左右4个三角形“拼接”而成;那么,为了实现最终的效果,即保留最下方的三角形,还应该怎么做?很简单,我们只需要把其它border边的颜色设置为白色或透明色:
div {
    width: 0;
    height: 0;
    border: 40px solid;
    border-color: transparent transparent red;
}

Duang~ 最终的简单三角形就绘制出来了。同理,如果想要得到其它边上的三角形,只需要将剩余的border边颜色设置为白色或透明色即可。
不过,被“隐藏”的上border仍然占据着空间,要想使得绘制出的三角形尺寸最小化,还需要将上border的宽度设置为0(其它情况同理):
div {
    width: 0;
    height: 0;
    border-width: 0 40px 40px;
    border-style: solid;
    border-color: transparent transparent red;
}
2. 实现带边框的三角形
带边框的三角形是指为三角形添加其它颜色的边框,如同为元素添加border一样:

由于不能继续通过为已有三角形设置border的方法来为其设置边框(因为三角形本身就是利用border实现的),所以只好另想办法。而能想到的一个最自然的方法就是三角形叠放,即把当前三角形叠放在更大的三角形上方,上图所示的实现方法就是把黄色三角形放在了尺寸更大的蓝色三角形上。
为了实现这样的效果,需要利用绝对定位方法:
首先定义出外面的蓝色三角形:
<div id="blue"><div>
#blue {
    position:relative;
    width: 0;
    height: 0;
    border-width: 0 40px 40px;
    border-style: solid;
    border-color: transparent transparent blue;
}
效果为:

随后需要定义黄色三角形,由于黄色三角形的定位需要参考蓝色三角形的位置,所以需要用到绝对定位方法。为此还需要将黄色三角形作为蓝色三角形的子元素。一个可行的办法是在蓝色三角形内部定义一个额外的标签以表示黄色三角形,但为了节约标签起见,更好的办法是使用伪元素:
#blue:after {
    content: "";
    width: 0;
    height: 0;
    position: absolute;
    top: 0px;
    left: 0px;
    border-width: 0 40px 40px;
    border-style: solid;
    border-color: transparent transparent yellow;
}
得到的效果为:

需要特别注意此时定义出的黄色三角形与蓝色三角形之间位置的偏移关系,该偏移将受到top、left(本例中)以及黄色三角形本身border宽度的共同影响。
可能会有这样的疑问:为什么黄色三角形会向左偏移一段距离呢,按道理不应该完全重合在蓝色三角形上吗,就像下面这样?

如果有这样的疑问,说明还没有对绝对定位产生足够的认识。绝对定位的区域是基于绝对定位父元素的padding区域,然后在此基础上运用top、left、right、bottom等一系列属性来约束绝对定位子元素的位置。在本例中,由于蓝色三角形作为绝对定位父元素,其内容的尺寸为0,则内容区域就是该三角形的上顶点:

对于黄色三角形,由于设置了left: 0和top: 0,所以黄色三角形的所有内容(包括border、margin)将根据蓝色三角形的上顶点进行定位。可以把此时left: 0和top: 0分别看作是两面“隔墙”——即上隔墙和左隔墙,黄色三角形的所有内容只能在上隔墙的下方和左隔墙的右方区域。
由于黄色三角形的内容区域也位于其顶点处,且对其设置了左右各40px的border,所以黄色三角形的内容区域将向右偏移40px,从而形成了之前的效果。
想想看将黄色三角形的位置设置为left: 0和bottom: 0,会得到怎样的定位效果?(下图所示)

搞懂了绝对定位后,只需要在原代码上稍作修改就可以将黄色三角形的顶点与蓝色三角形顶点相重合,同时还应该适当缩小黄色三角形的尺寸(按相似三角形等比例缩小):
#blue:after {
    content: "";
    position: absolute;
    top: 0px;
    left: -38px;
    border-width: 0 38px 38px;
    border-style: solid;
    border-color: transparent transparent yellow;
}
得到:

在上面的代码中,特意删除了之前对width: 0和height: 0的设置,因为子元素具有position:absolute设置,这会使得元素尺寸在不显式设置宽度和高度的情况下,收缩到元素内容的尺寸,由于内容设置的是content: "",所以子元素的尺寸默认也就是0了。故设置width: 0和height: 0就变得多余了。
最后一步就是利用top将黄色三角形向下移动至合适的位置:
#blue:after {
    content: "";
    position: absolute;
    top: 1px;
    left: -38px;
    border-width: 0 38px 38px;
    border-style: solid;
    border-color: transparent transparent yellow;
}
得到最终效果:

学会了带边框三角形的绘制,那么实现类似如下三角形箭头自然也是不在话下了:

实现代码:
#blue:after {
    content: "";
    position: absolute;
    top: 2px;
    left: -38px;
    border-width: 0 38px 38px;
    border-style: solid;
    border-color: transparent transparent #fff;
}
3. 绘制其它角度的三角形
绘制其它角度的三角形,如:

或者:

就更简单了,其实它们都是基于之前绘制的三角形而来的。如果想绘制右直角三角,则将左border设置为0;如果想绘制左直角三角,将右border设置为0即可(其它情况同理)。
CSS绘制三角形—border法的更多相关文章
- 纯CSS写三角形-border法
		(1)有边框的三角形 我们来写下带边框的三角形. 如果是一个正方形,我们写边时,会用到border,但我们这里讨论的三角形本身就是border,不可能再给border添加border属性,所以我们需要 ... 
- css绘制三角形原理
		1.新建一个元素,将它的宽高都设置为0:然后通过设置border属性来实现三角形效果,下面是css绘制三角形的原理: <!DOCTYPE html> <html> <he ... 
- CSS绘制三角形和箭头,不用再用图片了
		前言 还在用图片制作箭头,三角形,那就太lou了.css可以轻松搞定这一切,而且颜色大小想怎么变就怎么变,还不用担心失真等问题. 先来看看这段代码: /**css*/.d1{ width: 0; he ... 
- CSS 魔法系列:纯 CSS 绘制三角形(各种角度)
		我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 CSS3 的广泛使用,更多新奇的 CSS 作品涌现出来. ... 
- CSS学习笔记(8)--纯CSS绘制三角形(各种角度)
		纯CSS绘制三角形(各种角度) CSS三角形绘制方法,学会了这个,其它的也就简单. 我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多 ... 
- CSS绘制三角形和箭头
		<html> <head> <meta charset="utf-8"> <title>CSS绘制三角形和箭头</title& ... 
- 纯Css绘制三角形箭头三种方法
		在制作网页的过程中少不了绘制类似图片的三角形箭头效果,虽然工程量不大,但是确实麻烦.在学习的过程中,总结了以下三种方法,以及相关的例子. 一.三种绘制三角形箭头方法 1.方法一:利用overflow: ... 
- CSS绘制三角形的原理剖析
		今天学习Bootstrap时候,看到按钮的向下三角形源码: .caret { display: inline-block; ; ; margin-left: 2px; vertical-align: ... 
- 用CSS绘制三角形
		其实用HTML CSS绘制三角行 是非常简单的 ,我在网上看了不少人写的博客,里面写的好复杂样子,反正我是看的云里雾里的,说实话是挺简单的. 首先提出一段代码: <!DOCTYPE html&g ... 
随机推荐
- php 5.6.36 安装mcrypt
			相关扩展安装步骤 libmcrypt downloadUrl:https://sourceforge.net/projects/mcrypt/files/MCrypt/ versionCode:2.5 ... 
- 【转载】Asp.Net中Cookie对象的作用以及常见属性
			Cookie对象是服务器为用户访问存储的特定信息,这些信息一般存储在浏览器中,服务器可以从提交的数据中获取到相应的Cookie信息,Cookie的最大用途在于服务器对用户身份的确认,即票据认证,用户会 ... 
- 【转载】C#中将字符串分割成字符数组
			在C#中字符串类型String是由一系列的单个字符组合而成,其实可以通过字符串String对象ToCharArray()方法来将字符串中的元素逐一存在数据类型为Char的一维数组中. 例如将字符str ... 
- 十年感悟之 python之路
			本文由 简悦 SimpRead 转码, 原文地址 https://laisky.com/p/python-road/ Changelog: updated at 2019/9/6 一.概述 本文起源于 ... 
- Jerry Wang从2017年到2019年的自由泳学习笔记
			打腿 把注意力调整到脚部,尽量不要让他打出水面,因为在空气中大腿完全是无用功,但是如果只是脚跟出水一点,倒也没什么关心,但是主观上,要控制一下,如果你听到你的打腿是"咚咚咚咚"这样 ... 
- 使用browser-sync预览pandoc markdown???
			由于 pandoc markdown在sublime下面并不能很好的预览,因此可以直接 使用 pandoc build成html,然后借助下面的工具进行实时在浏览器里面预览 http://www.br ... 
- 【SpringMVC】参数绑定
			一.概述 1.3 参数绑定过程 1.2 @RequestParam 二.自定义绑定使用属性编辑器 2.1 使用WebDataBinder(了解) 2.2 使用WebBindingInitializer ... 
- TIME_WAIT状态全是3306解决办法
			刚吃完晚饭,手机短信一直响个不停,打开一看全是告警信息,立即打开电脑查看,发现很多网页很不稳定 一会能打开,一会打不开 登录服务器查看负载情况,cpu.内存 .磁盘io 负载都不高,查看日志发现ng ... 
- Vim使用技巧(0) -- 博主的vim配置
			vim ~/.vimrc "插入模式时 光标的上下左右移动 inoremap <C-l> <Right> inoremap <C-h> <Left& ... 
- kafka读书笔记《kafka并不难学》
			======第一章 1 在高并发场景,如大量插入.更新数据库会导致锁表,导致连接数过多的异常,此时需要消息队列来缓冲一下.消息队列通过异步处理请求来缓解压力 2 消息队列采用异步通信机制消息队列拥有先 ... 
