css3能不能实现三角形

css3能实现三角形,有多种实现方法:1、利用高宽为零的容器和透明的border绘制三角形;2、利用线性渐变linear-gradient绘制三角形;3、利用conic-gradient绘制三角形;4、利用clip-path绘制三角形等。

css3能不能实现三角形

本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。

css3中可以使用多种方法实现三角形。下面就来看看:

1、使用 border 绘制三角形

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

登录后复制

html, body {  width: 100%;  height: 100%;  display: flex;}div {  width: 0px;  height: 0px;  margin: auto;}.top {  border: 50px solid transparent;  border-bottom: 50px solid deeppink;}.left {  border: 50px solid transparent;  border-right: 50px solid deeppink;}.bottom {  border: 50px solid transparent;  border-top: 50px solid deeppink;}.right {  border: 50px solid transparent;  border-bottom: 50px solid deeppink;}

登录后复制

1.png

立即学习“前端免费学习笔记(深入)”;

2、使用 linear-gradient 绘制三角形

登录后复制

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

登录后复制

2.png

3、使用 conic-gradient 绘制三角形

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

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

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

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

6.png

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

7.gif

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

.normal {    background: conic-gradient(from 90deg at 50% 0, deeppink 0, deeppink 45deg, transparent 45.1deg);}.acute {    background: conic-gradient(from 90deg at 50% 0, transparent 0, transparent 45deg, deeppink 45.1deg, deeppink 135deg, transparent 1deg);}

登录后复制

3.png

4、transform: rotate 配合 overflow: hidden 绘制三角形

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

2.gif

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

完整的代码:

登录后复制

html, body {    width: 100%;    height: 100%;    display: flex;}div {    width: 141px;    height: 100px;    margin: auto;}.demo-opacity {    overflow: hidden;}.demo,.demo-opacity {    position: relative;    border: 1px solid #000;    background: unset;        &::before {        content: "";        position: absolute;        top: 0;        left: 0;        right: 0;        bottom: 0;        animation: conicmove 3s infinite linear;        background: deeppink;        transform-origin: left bottom;        z-index: -1;    }}.triangle {    position: relative;    background: unset;    overflow: hidden;        &::before {        content: "";        position: absolute;        top: 0;        left: 0;        right: 0;        bottom: 0;        background: deeppink;        transform-origin: left bottom;        transform: rotate(45deg);        z-index: -1;    }}@keyframes conicmove {    100% {        transform: rotate(45deg);    }}

登录后复制

5、使用 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);}

登录后复制

10.png

(学习视频分享:css视频教程)

以上就是css3能不能实现三角形的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2936760.html

(0)
上一篇 2025年3月11日 21:04:42
下一篇 2025年3月4日 21:32:02

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • css3中类选择器是什么

    在css3中,类选择器指的是class选择器,它允许以一种独立于文档元素的方式来指定样式,用于描述一组元素的样式,可以在多个元素中使用。类选择器在HTML中以class属性表示,在CSS中以一个点“.”号显示。 本教程操作环境:window…

    2025年3月11日
    200
  • css3中什么属性定义盒子高度

    css3定义盒子高度的属性:1、height属性,可设置元素盒子的高度;2、max-height属性,可设置元素盒子的最大高度;3、min-height属性,可设置元素盒子的最小高度。 本教程操作环境:windows7系统、CSS3&amp…

    2025年3月11日 编程技术
    200
  • css3伪元素有哪些

    css3伪元素有:1、“::after”,可在指定元素的后面插入一些内容;2、“::before”;3、“::first-letter”;4、“::first-line”;5、“::selection”;6、“::placeholder”。…

    2025年3月11日 编程技术
    200
  • css3怎么实现字体放大缩小动画

    实现方法:1、使用“@keyframes”规则和“transform:scale(缩放比例);”语句创建字体放大缩小动画;2、使用“字体元素{animation:动画名称 时间 infinite;}”语句将缩放动画应用于字体元素中即可。 本…

    2025年3月11日
    200
  • css3 scale表示什么

    在css3中,scale表示“缩放”,是运用于transform属性的内置函数,用于对指定元素进行2D或3D的缩放转换;scale函数有多种,包括:scale()、scaleX()、scaleY()、scaleZ()、scale3d()。 …

    2025年3月11日 编程技术
    200
  • css3渐变有几种

    css3渐变有2种:1、linear-gradient()函数创建的线性渐变,沿着一根轴线改变颜色,从起点到终点颜色进行顺序渐变;2、radial-gradient()函数创建的径向渐变,从起点到终点颜色从内而外沿进行圆形渐变。 本教程操作…

    2025年3月11日 编程技术
    200
  • 什么是css3的flexbox

    flexbox的意思为“弹性盒子”,是CSS3引入的新的布局模式,是一种可伸缩的灵活的web页面布局方式;Flexbox布局模式能够扩展和收缩flex容器内的元素,以最大限度地填充可用空间。 本教程操作环境:windows7系统、CSS3&…

    2025年3月11日 编程技术
    200
  • css3贝塞尔曲线函数有几个参数

    css3贝塞尔曲线函数cubic-bezier()有4个参数,分别指定曲线两个相互分离的中间点的坐标,语法为“cubic-bezier(x1,y1,x2,y2)”;参数x1、y1、x2、y2的取值范围为0到1。 本教程操作环境:window…

    2025年3月11日 编程技术
    200
  • css3中rgba是什么

    rgba是css3中一种定义颜色的函数,语法为“rgba(R,G,B,A)”,代表由红(R)、绿(G)、蓝(B)和透明度(A)的变化以及相互叠加来得到各式各样的颜色;参数R、G、B的取值范围为“0~255”,A的取值范围为“0~1”。 本教…

    2025年3月11日
    200
  • css3支持的滤镜是什么

    css3支持的滤镜是由filter属性定义的可视效果,包括:1、模糊滤镜,可给图像设置高斯模糊;2、亮度滤镜;3、对比度滤镜;4、投影滤镜;5、灰度滤镜;6、色相旋转滤镜;7、反转图像滤镜;8、透明度滤镜;9、饱和度滤镜;10、深褐色滤镜。…

    2025年3月11日
    200

发表回复

登录后才能评论