1. 实现一个简单的三角形

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

CSS实现简单三角形

实现原理:

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

div {

width: 50px;

height: 50px;

border: 2px solid orange;

}

效果图:

border的一般使用

这是我们平常使用border最普遍的情况——往往只给border一个较小的宽度(通常为1-2px);然而这样的日常用法就会容易让大家对border的形成方式产生 误解 ,即认为元素的border是由四个矩形边框拼接而成。

然而事实并不是这样。实际上,元素的border是由 三角形 组合而成,为了说明这个问题,我们可以增大border的宽度,并为各border边设置不同的颜色:

div {

width: 50px;

height: 50px;

border: 40px solid;

border-color: orange blue red green;

}

效果图:

border的形成方式

既然如此,那么更进一步,把元素的内容尺寸设置为0会发生什么情况呢?

div {

width: 0;

height: 0;

border: 40px solid;

border-color: orange blue red green;

}

效果图:

元素内容尺寸为0

我们将惊奇地发现,此时元素由上下左右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 ,会得到怎样的定位效果?(下图所示)

黄色三角形设置为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即可(其它情况同理)。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

html直角三角形怎么实现,CSS绘制三角形的实现代码(border法)相关推荐

  1. css画横线箭头_用CSS绘制三角形箭头

    用CSS绘制三角形箭头.使用纯CSS,你只需要很少的代码就可以创作出各种浏览器都兼容的三角形箭头! CSS代码:/* create an arrow that points up */ div.arr ...

  2. html css右下角三角形,纯CSS绘制三角形(各种角度)

    CSS/HTML 的 纯CSS绘制三角形(各种角度) 我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 C ...

  3. css 绘制三角形_解释CSS形状:如何使用纯CSS绘制圆,三角形等

    css 绘制三角形 Before we start. If you want more free content but in video format. Don't miss out on my Y ...

  4. html div三角形,【div】纯CSS绘制三角形

    原标题:[div]纯CSS绘制三角形 我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 CSS3 的广泛使 ...

  5. CSS绘制三角形图标

    CSS绘制三角形图标目录 1CSS绘制三解形图标原理 2 页面效果 3 HTML结构 4 CSS样式 1CSS绘制三解形图标原理 对内容容器进行相对定位,对内容容器的伪元素:before和:after ...

  6. 使用html+CSS绘制三角形

    使用html+CSS绘制三角形 前言 一.绘制正方形 二.进行外边框填充 三.把盒子的宽高设置为0 四.要哪边的三角形就把哪边设置为透明 五.最终化简代码 前言 使用html+CSS绘制三角形,三角形 ...

  7. css绘制的画眉鸟代码

    下载地址 css绘制的画眉鸟代码 dd:

  8. 三角形css_使用css绘制三角形

    好看的前端网页大家见到的应该都不少 但是很多都是用图片作为背景 今天我们就给大家讲讲怎么用css绘制图形 (图形如下) ---------------------------------------- ...

  9. CSS:N种使用CSS 绘制三角形的方法

    目录 6种使用 CSS 实现三角形的技巧 1.使用 border 绘制三角形 2.使用 linear-gradient 绘制三角形 3.使用 conic-gradient 绘制三角形 4.transf ...

最新文章

  1. css3之border-radius理解
  2. mysql安装教程8.0.21安装,mysql 8.0.21 安装配置方法图文教程
  3. 微软最具想象力项目:将数据中心沉入海底
  4. Fedora 34 Beta发布:引入GNOME 40巨大桌面升级
  5. Redis面试复习大纲在手面试不慌,讲的明明白白!
  6. c++ doxygen 注释规范_利用Doxygen给C程序生成注释文档
  7. linux命令之有关网络的操作命令
  8. Cognos8.3 + oracle9i数据集市 建cube性能调整
  9. 注册表java参数_Java通过CMD方式读取注册表任意键值对代码实践
  10. 2、树莓派声卡设置和alsactl命令的使用
  11. 如何快速将jpg格式文件转换成bmp格式
  12. Linux高级网络开发奇妙之旅
  13. WPS2017 电子表格/Excel文件保护密码忘记了?
  14. 导入EXCEL2007报错外部表不是预期的格式错误
  15. 【SQL必知必会】002-基础篇:了解SQL:一门半衰期很长的语言
  16. Linux命令uname -a和uname -r的详解 2022_11_30
  17. 掺镱光纤激光器 RP Fiber Power
  18. 基于Unity的C#中各类函数使用方法及示例
  19. matlab基于SVM的手写字体识别,机器学习SVM--基于手写字体识别
  20. 北京超声刀治疗痘印有效吗

热门文章

  1. Windows AIK+Imagex+DISM+U盘PE+U盘安装win7+PE
  2. Linux文件目录结构详解
  3. scrapy框架下设置代理ip
  4. 音视频播放器关键技术探讨
  5. java中info()_java日志中的info是啥意思
  6. 【题解】慈溪中学-8.13-T1
  7. AIX5.3、AIX6.0 AIX操作系统安全加固
  8. LabView程序上传systemlink
  9. P60 整型数据类型讲解
  10. 跨考 深大计算机,深圳大学!一所比985还要热门的双非!还很壕气!