广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >怎么用CSS绘制三角形
  • 838
分享到

怎么用CSS绘制三角形

2024-04-02 19:04:59 838人浏览 安东尼
摘要

本篇内容介绍了“怎么用CSS绘制三角形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用 border 绘

本篇内容介绍了“怎么用CSS绘制三角形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

使用 border 绘制三角形

使用 border 实现三角形应该是大部分人都掌握的,也是各种面经中经常出现的,利用了高宽为零的容器及透明的 border 实现。

简单的代码如下:

div {   border-top: 50px solid yellowgreen;   border-bottom: 50px solid deeppink;   border-left: 50px solid bisque;   border-right: 50px solid chocolate; }

高宽为零的容器,设置不同颜色的 border:

怎么用CSS绘制三角形

这样,让任何三边的边框的颜色为 transparent,则非常容易得到各种角度的三角形:

怎么用CSS绘制三角形

CodePen Demo - 使用 border 实现三角形[1]

使用 linear-gradient 绘制三角形

接着,我们使用线性渐变 linear-gradient 实现三角形。

它的原理也非常简单,我们实现一个 45° 的渐变:

div {   width: 100px;   height: 100px;   background: linear-gradient(45deg, deeppink, yellowgreen); }

怎么用CSS绘制三角形

让它的颜色从渐变色变为两种固定的颜色:

div {   width: 100px;   height: 100px;   background: linear-gradient(45deg, deeppink, deeppink 50%, yellowgreen 50%, yellowgreen 100%); }

怎么用CSS绘制三角形

再让其中一个颜色透明即可:

div {   background: linear-gradient(45deg, deeppink, deeppink 50%, transparent 50%, transparent 100%); }

怎么用CSS绘制三角形

通过旋转 rotate 或者 scale,我们也能得到各种角度,不同大小的三角形,完整的 Demo 可以戳这里:

CodePen Demo - 使用线性渐变实现三角形[2]

使用 conic-gradient 绘制三角形

还是渐变,上述我们使用了线性渐变实现三角形,有意思的是,在渐变家族中,角向渐变 conic-gradient 也可以用于实现三角形。

方法在于,角向渐变的圆心点是可以设置的,类似于径向渐变的圆心点也可以被设置。

我们将角向渐变的圆心点设置于 50% 0,也就是 center top,容器最上方的中间,再进行角向渐变,渐变到一定的角度范围内,都是三角形图形。

假设我们有一个 200px x 100px 高宽的容器,设置其角向渐变圆心点为 50% 0:

怎么用CSS绘制三角形

并且,设置它从 90° 开始画角向渐变图,示意图如下:

怎么用CSS绘制三角形

角向渐变逐渐变化动画

可以看到,在初始的时候,角向渐变图形没有到第二条边的之前,都是三角形,我们选取适合的角度,非常容易的可以得到一个三角形:

div {     background: conic-gradient(from 90deg at 50% 0, deeppink 0, deeppink 45deg, transparent 45.1deg); }

怎么用CSS绘制三角形

利用 conic-gradient 实现的三角形

上述代码中的 deeppink 45deg, transparent 45.1deg 多出来的 0.1deg  是为了简单消除渐变产生的锯齿的影响,这样,我们通过 conic-gradient,也轻松的得到了一个三角形。

同理,再配合旋转 rotate 或者 scale,我们也能得到各种角度,不同大小的三角形,完整的 Demo 可以戳这里:

CodePen Demo - 使用角向渐变实现三角形[3]

transfORM: rotate 配合 overflow: hidden 绘制三角形

这种方法还是比较常规的,使用 transform: rotate 配合 overflow:  hidden。一看就懂,一学就会,简单的动画示意图如下:

怎么用CSS绘制三角形

设置图形的旋转中心在左下角 left bottom,进行旋转,配合 overflow: hidden。

完整的代码:

.triangle {     width: 141px;     height: 100px;     position: relative;     overflow: hidden;          &::before {         content: "";         position: absolute;         top: 0;         left: 0;         right: 0;         bottom: 0;         background: deeppink;         transform-origin: left bottom;         transform: rotate(45deg);     } }

CodePen Demo - transform: rotate 配合 overflow: hidden 实现三角形[4]

使用 clip-path 绘制三角形

clip-path 一个非常有意思的 CSS 属性。

clip-path CSS 属性可以创建一个只有元素的部分区域可以显示的剪切区域。区域内的部分显示,区域外的隐藏。剪切区域是被引用内嵌的 URL  定义的路径或者外部 SVG 的路径。

也就是说,使用 clip-path 可以将一个容器裁剪成任何我们想要的样子。

通过 3 个坐标点,实现一个多边形,多余的空间则会被裁减掉,代码也非常简单:

div {     background: deeppink;     clip-path: polyGon(0 0, 100% 0, 0 100%, 0 0); }

怎么用CSS绘制三角形

利用 clip-path 实现的三角形

CodePen Demo - 使用 clip-path 实现三角形[5]

在这个网站中 -- CSS clip-path maker[6],你可以快捷地创建简单的 clip-path 图形,得到对应的 CSS 代码。

怎么用CSS绘制三角形

利用字符绘制三角形

OK,最后一种,有些独特,就是使用字符表示三角形。

下面列出一些三角形形状的字符的十进制 Unicode 表示码。

◄ : ◄  ► : ►  ▼ : ▼  ▲ : ▲ ⊿ : ⊿ △ : △

譬如,我们使用 ▼ 实现一个三角形 ▼,代码如下:

<div class="normal">&#9660; </div>
div {     font-size: 100px;     color: deeppink; }

效果还是不错的:

怎么用CSS绘制三角形

利用字符实现的三角形

然而,需要注意的是,使用字符表示三角形与当前设定的字体是强相关的,不同的字体绘制出的同一个字符是不一样的,我在 Google Font[7]  上随机选取了几个不同的字体,分别表示同一个字符,得到的效果如下:

怎么用CSS绘制三角形

可以看到,不同字体的形状、大小及基线都是不一样的,所以如果你想使用字符三角形,确保用户的浏览器安装了你指定的字体,否则,不要使用这种方式。

“怎么用CSS绘制三角形”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: 怎么用CSS绘制三角形

本文链接: https://www.lsjlt.com/news/80368.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • CSS怎么绘制三角形
    本篇文章给大家分享的是有关CSS怎么绘制三角形,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、绘制方法画出三角形的原理是调整border(边框)的四个方向的宽度,线条样式以及...
    99+
    2023-06-15
  • 怎么用CSS绘制三角形
    本篇内容介绍了“怎么用CSS绘制三角形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用 border 绘...
    99+
    2022-10-19
  • 怎样利用CSS绘制三角形
    这篇文章给大家分享的是有关怎样利用CSS绘制三角形的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在一些面经中,经常能看到有关 CSS 的题目都会有一道如何使用 CSS 绘制三角形,而经常的回答通常也只有使用 bo...
    99+
    2023-06-15
  • 如何用css绘制三角形
    本文小编为大家详细介绍“如何用css绘制三角形”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何用css绘制三角形”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。   首先,我...
    99+
    2022-10-19
  • 怎么使用CSS代码绘制三角形
    本篇内容主要讲解“怎么使用CSS代码绘制三角形”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用CSS代码绘制三角形”吧!1、绘制方法画出三角形的原理是调整border(边框)的四个方向的宽...
    99+
    2023-07-05
  • CSS怎么绘制三角形和箭头
    本篇内容主要讲解“CSS怎么绘制三角形和箭头”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS怎么绘制三角形和箭头”吧!先来看看这段代码: .d1{ &nbs...
    99+
    2022-10-19
  • 如何使用CSS绘制三角形
    如何使用CSS绘制三角形?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 实现一个简单的三角形使用CSS盒模型中的border(边框)即可实现如下所示的三角形:CSS实现简单...
    99+
    2023-06-08
  • 如何利用css绘制三角形
    这篇文章给大家分享的是有关如何利用css绘制三角形的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。以下是常用的三角形形状其实都是html+css就能实现,很简单代码如下:第一种方法html代码:代码如下:<!...
    99+
    2023-06-08
  • 怎么用CSS绘制三角形箭头效果
    这篇文章主要讲解了“怎么用CSS绘制三角形箭头效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用CSS绘制三角形箭头效果”吧!使用纯CSS,你只需要很...
    99+
    2022-10-19
  • 怎么用CSS绘制三角形箭头图案
    这篇文章主要介绍“怎么用CSS绘制三角形箭头图案”,在日常操作中,相信很多人在怎么用CSS绘制三角形箭头图案问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用CSS绘制三角...
    99+
    2022-10-19
  • CSS中如何绘制三角形
    这篇“CSS中如何绘制三角形”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“CSS中如何绘制三角形”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们一起来看看具...
    99+
    2023-06-08
  • CSS中怎么使用transparent属性绘制三角形
    CSS中怎么使用transparent属性绘制三角形,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。示例代码<!DOCTYPE ...
    99+
    2022-10-19
  • css如何使用border绘制三角形
    小编给大家分享一下css如何使用border绘制三角形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!使用 border 绘制三角...
    99+
    2022-10-19
  • 纯CSS绘制三角形的方法
    本篇内容主要讲解“纯CSS绘制三角形的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“纯CSS绘制三角形的方法”吧!CSS绘制三角形的方法:1、定义个宽高为0的标签元素;2、使用“border...
    99+
    2023-06-14
  • css如何使用clip-path绘制三角形
    这篇文章主要为大家展示了“css如何使用clip-path绘制三角形”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css如何使用clip-path绘制三角形”这...
    99+
    2022-10-19
  • css如何使用conic-gradient绘制三角形
    这篇文章将为大家详细讲解有关css如何使用conic-gradient绘制三角形,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用 conic-gradient 绘制三角...
    99+
    2022-10-19
  • css如何使用linear-gradient绘制三角形
    这篇文章将为大家详细讲解有关css如何使用linear-gradient绘制三角形,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用 linear-gradient 绘制...
    99+
    2022-10-19
  • 怎么用mfc绘制随机三角形
    要使用MFC(Microsoft Foundation Classes)绘制随机三角形,你可以按照以下步骤进行操作:1. 打开 Vi...
    99+
    2023-09-16
    mfc
  • CSS绘制三角形的方法有哪些
    本篇内容主要讲解“CSS绘制三角形的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS绘制三角形的方法有哪些”吧!使用 border 绘制三角形使用 border 实现三角形应该是大...
    99+
    2023-07-05
  • 怎么使用C++的OpenGL绘制三角形
    这篇文章主要讲解了“怎么使用C++的OpenGL绘制三角形”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用C++的OpenGL绘制三角形”吧!一、绘制三角形1、初始化(1)初始化GLF...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作