0


【CSS】CSS实现三角形(一)

话不多说,下面介绍两种比较常用的写法:

一、border边框

宽和高都设置为0px,通过border的交点创建三角形,这应该是使用的最多的一种写法。

.triangle{
    width: 0;
    height: 0;
    border: 100px solid;
    border-color: red green blue orange;
}

效果图如下:

好了,四个小三角已经初见雏形了,只需要稍做修改,就能一个个拿出来。

1、上三角

原理简单粗暴,既然我只需要最上面的那个小三角,其他几个角的边框颜色设置为透明即可。

.triangle{
    width: 0;
    height: 0;
    border-top: 100px solid red;
    border-left: 100px solid transparent;
    border-right: 100px solid transparent;
}

效果图:

2、下三角

.triangle{
    width: 0;
    height: 0;
    border-bottom: 100px solid blue;
    border-left: 100px solid transparent;
    border-right: 100px solid transparent;
}

效果图:

3、左三角

.triangle{
    width: 0;
    height: 0;
    border-left: 100px solid orange;
    border-top: 100px solid transparent;
    border-bottom: 100px solid transparent;
}

效果图:

4、右三角

.triangle{
    width: 0;
    height: 0;
    border-right: 100px solid green;
    border-top: 100px solid transparent;
    border-bottom: 100px solid transparent;
}

效果图:

不过需要注意的是,其他的几个边还是占据空间的哦,一般会配合定位position来用。

5、直角三角形

如果需要直角三角形,上面的写法似乎并不满足,换个思路,看下面:

.triangle1{
    width: 0;
    height: 0;
    border-top: 100px solid red;
    border-right: 100px solid transparent;
}
.triangle2{
    width: 0;
    height: 0;
    border-bottom: 100px solid red;
    border-left: 100px solid transparent;
}
.triangle3{
    width: 0;
    height: 0;
    border-bottom: 100px solid red;
    border-right: 100px solid transparent;
}
.triangle4{
    width: 0;
    height: 0;
    border-top: 100px solid red;
    border-left: 100px solid transparent;
}

效果如下:

除了border之外,还有没有什么办法也可以实现三角形的效果呢?

二、 linear-gradient渐变

对,你没有看错,就是渐变。具体需要怎么操作呢?

1、直角三角形

这里我们需要配合background-image使用,下面说一下思路:

(1)先设定一个长宽均为100px的正方形

(2)设定渐变轴,这里需要获取到的是直角三角形,我们可以简单的设定轴的方向是45度或者-45度,可以结合border边框下最开始的那四个小三角来思考。45度和-45度相当于各为两个三角形,方向不同而已。

(3)现在开始设置渐变色,其中一个颜色设置为透明,并且第一个颜色停止渲染的位置是在50%,这样,一个三角形就绘制出来了。

.triangle1{
      width: 100px;
      height: 100px;
      background-repeat: no-repeat;
    background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0) 50%, #f00 50%);
}
.triangle2{
      width: 100px;
      height: 100px;
    background-image: linear-gradient(-45deg, #f00 50%, rgba(255, 255, 255, 0) 50%);
}
.triangle3{
      width: 100px;
      height: 100px;
      background-repeat: no-repeat;
    background-image: linear-gradient(45deg, #f00 50%, rgba(255, 255, 255, 0) 50%);
}
.triangle4{
      width: 100px;
      height: 100px;
    background-image: linear-gradient(45deg, rgba(255, 255, 255, 0) 50%, #f00 50%);
}

效果如下:

2、非直角三角形

非直角三角形需要注意的就是,角度需要根据设置的宽高自行调整。

.triangle {
    width: 100px;
      height: 100px;
      background-repeat: no-repeat;
    background-image: linear-gradient(26deg, red 50%, rgba(255, 255, 255, 0) 50%), linear-gradient(154deg, green 50%, rgba(255, 255, 255, 0) 50%);
    background-size: 100% 50%;
    background-position: top left, bottom left;
}

这里为了区分,放了两种颜色,用的时候可以把颜色统一就OK了。

其他方向的三角形大家也可以自己参考着试一试哦,本文就先告一段落了。

下一篇文章将会通过伪元素的方式实现三角形:CSS实现三角形(二)

另外,如果有什么其他好方法也可以评论区补充哦!

标签: css 前端 javascript

本文转载自: https://blog.csdn.net/weixin_38629529/article/details/126440388
版权归原作者 想上天的小鱼 所有, 如有侵权,请联系我们删除。

“【CSS】CSS实现三角形(一)”的评论:

还没有评论