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实现的),所以只好另想办法。而能想到的一个最自然的方法就是三角形叠放,即把当前三角形叠放在更大的三角形上方,上图所示的实现方法就是把黄色三角形放在了尺寸更大的蓝色三角形上。
为了实现这样的效果,需要利用绝对定位方法:
首先定义出外面的蓝色三角形:
#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法相关推荐
- css绘制向左三角形_CSS绘制三角形—border法
1. 实现一个简单的三角形 使用CSS盒模型中的border(边框)即可实现如下所示的三角形: CSS实现简单三角形 实现原理: 首先来看在为元素添加border时,border的样子:假设有如下代码 ...
- css 绘制三角形_解释CSS形状:如何使用纯CSS绘制圆,三角形等
css 绘制三角形 Before we start. If you want more free content but in video format. Don't miss out on my Y ...
- CSS绘制三角形图标
CSS绘制三角形图标目录 1CSS绘制三解形图标原理 2 页面效果 3 HTML结构 4 CSS样式 1CSS绘制三解形图标原理 对内容容器进行相对定位,对内容容器的伪元素:before和:after ...
- 使用html+CSS绘制三角形
使用html+CSS绘制三角形 前言 一.绘制正方形 二.进行外边框填充 三.把盒子的宽高设置为0 四.要哪边的三角形就把哪边设置为透明 五.最终化简代码 前言 使用html+CSS绘制三角形,三角形 ...
- css画横线箭头_用CSS绘制三角形箭头
用CSS绘制三角形箭头.使用纯CSS,你只需要很少的代码就可以创作出各种浏览器都兼容的三角形箭头! CSS代码:/* create an arrow that points up */ div.arr ...
- html css右下角三角形,纯CSS绘制三角形(各种角度)
CSS/HTML 的 纯CSS绘制三角形(各种角度) 我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 C ...
- html div三角形,【div】纯CSS绘制三角形
原标题:[div]纯CSS绘制三角形 我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 CSS3 的广泛使 ...
- 三角形css_使用css绘制三角形
好看的前端网页大家见到的应该都不少 但是很多都是用图片作为背景 今天我们就给大家讲讲怎么用css绘制图形 (图形如下) ---------------------------------------- ...
- CSS:N种使用CSS 绘制三角形的方法
目录 6种使用 CSS 实现三角形的技巧 1.使用 border 绘制三角形 2.使用 linear-gradient 绘制三角形 3.使用 conic-gradient 绘制三角形 4.transf ...
- CSS绘制三角形原理及应用
更多精彩内容可以访问我的博客Aelous-BLog 在从 PSD 到 HTML 页面的过程中,免不了要遇到一个问题:"这个小图标,可以用 CSS 效果实现,也可以切图下来,到底该怎么选择呢? ...
最新文章
- java synchronized wait
- 双时隙的工作原理_双联开关的工作原理
- foundApp宣传展示页企业网站模板
- Python爬虫入门教程 44-100 Charles的安装与使用-手机APP爬虫部分
- mysql 5.7 plugin 安装_mysql5.7以上版本安装
- 最新隐马尔可夫模型HMM详解
- c#进度条刻度_自定义滑动刻度进度条
- java万年历代码_JAVA实现的简单万年历代码
- 单词吸血鬼源代码 二叉树操作
- 服务器word文档会是只读的,Word自动变只读模式怎么办? 这样可取消Word只读
- android波纹动画,Android实现水波纹特效
- IE8中怎样使用脚本隐藏弹出窗口的地址栏
- 维谛技术Vertiv 暑期实习
- 歌斐资产CEO殷哲谈资产的转型升级
- 利用jQuery UI为CMS网站实现拖拽布局效果,秒杀table布局
- 药品注册专员前景如何?5条职业规划发展方向
- 16、爬取知乎大v张佳玮的文章“标题”、“摘要”、“链接”,并存储到本地文件...
- 网络安全工程师考证指南
- matlab中随机抽取函数,matlab 哪个函数可以从一组数据中随机抽取一部分出来
- SecureCRT、Xmanager对Linux上传下载文件或文件夹
热门文章
- 微信小程序父子组件传值
- 麦肯锡三部曲_《麦肯锡精英高效阅读法》| 认知的四种境界,来看看自己在哪一层...
- matlab for 数组,Matlab数组
- Redis中文翻译系列---Redis文档
- 深度 | 面目全非自动化
- html注册页面教程视频,新手建站HTML 学习系列视频教程之HTML 简介
- EXCEL VBA批量下载URL链接地址图片、URL链接地址图片转为图片
- 数据库实验——T-SQL编程
- 技术美术个人笔记(三)——各贴图格式
- ASP.NET Core MVC 入门到精通 - 1. 开发必备工具 (2021)