• 技术文章 >web前端 >前端问答

    css3能不能实现三角形

    青灯夜游青灯夜游2022-03-07 16:40:38原创47

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

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

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

    1、使用 border 绘制三角形

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

    <div class='top'></div>
    <div class='bottom'></div>
    <div class='left'></div>
    <div class='right'></div>
    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></div>
    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

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

    <div class="normal"></div>
    <div class="acute"></div>
    
    .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

    完整的代码:

    <div class="demo"></div>
    <div class="demo-opacity"></div>
    <div class="triangle"></div>
    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能不能实现三角形的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:css3 三角形
    上一篇:css3怎么实现鼠标滑过隐现效果 下一篇:symbol是es6中的新增类型吗
    PHP编程就业班

    相关文章推荐

    • css3新增的背景属性有哪些• transform是css3新增的属性吗• css3中用什么来定义过渡动画的时间• css3实现多栏布局有哪几种方法• 在css3中box-shadow什么意思• CSS3中过渡与动画的区别是什么• css3怎么实现鼠标滑过隐现效果

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网