CSS技巧-CSS的形状有很多不同的CSS形状,我特别困惑于三角形:

#三角形向上{宽度:0;高度:0;左边框:50px实心透明;右边框:50px实心透明;边框底部:100px纯红色;}<div id=“triangle up”></div>

它是如何以及为什么工作的?


当前回答

从基本的正方形和边框开始。每个边框将被赋予不同的颜色,以便我们可以区分它们:

.三角形{边框颜色:黄-蓝-红-绿;边框样式:实心;边框宽度:200px 200px 200px 200px;高度:0px;宽度:0px;}<div class=“triangle”></div>

这为您提供了:

但不需要顶部边框,因此将其宽度设置为0px。现在,200px的边框底部将使我们的三角形变高200px。

.三角形{边框颜色:黄-蓝-红-绿;边框样式:实心;边框宽度:0px 200px 200px;高度:0px;宽度:0px;}<div class=“triangle”></div>

我们将得到:

然后,要隐藏两个边三角形,请将边框颜色设置为透明。由于顶部边框已被有效删除,因此我们也可以将边框顶部颜色设置为透明。

.三角形{边框颜色:透明透明红色透明;边框样式:实心;边框宽度:0px 200px 200px;高度:0px;宽度:0px;}<div class=“triangle”></div>

最后我们得到了:

其他回答

好的,这个三角形将被创建,因为元素的边框在HTML和CSS中一起工作的方式。。。

由于我们通常使用1或2px边框,我们从未注意到边框以相同的宽度彼此成45°角,如果宽度发生变化,角度也会发生变化,请运行我在下面创建的CSS代码:

.三角形{宽度:100px;高度:100px;左边框:50px实心黑色;右边框:50px实心黑色;边框底部:100px纯红色;}<div class=“triangle”></div>

然后在下一步中,我们没有任何宽度或高度,如下所示:

.三角形{宽度:0;高度:0;左边框:50px实心黑色;右边框:50px实心黑色;边框底部:100px纯红色;}<div class=“triangle”></div>

现在,我们使左边界和右边界不可见,以使理想的三角形如下所示:

.三角形{宽度:0;高度:0;左边框:50px实心透明;右边框:50px实心透明;边框底部:100px纯红色;}<div class=“triangle”></div>

如果您不愿意运行代码片段来查看步骤,我创建了一个图像序列,以查看一个图像中的所有步骤:

边框在相交处使用有角度的边(与等宽边框成45°角,但更改边框宽度可能会扭曲角度)。

第二部分{宽度:60px;边框宽度:30px;边框颜色:红蓝绿黄;边框样式:实心;}<div></div>

看看jsFiddle。

通过隐藏某些边界,您可以获得三角形效果(正如您在上面看到的,通过使不同部分的颜色不同)。透明经常被用作边缘颜色以获得三角形形状。

如果您想将边框应用于三角形,请阅读以下内容:使用CSS创建三角形?

几乎所有的答案都集中在使用边界构建的三角形上,所以我将详细介绍线性梯度方法(从@lima_fil的答案开始)。

使用像45°这样的度数值将迫使我们遵守特定的高度/宽度比,以获得我们想要的三角形,这不会是响应性的:

.tri三{宽度:100px;高度:100px;背景:线性梯度(45度,透明49.5%,红色50%);/*为了说明*/边框:1px实心;}很好<div class=“tri”></div>坏的一个<div class=“tri”style=“width:150px”></div>坏的一个<div class=“tri”style=“height:30px”></div>

相反,我们应该考虑预定义的方向值,如底部、顶部等。在这种情况下,我们可以获得任何类型的三角形,同时保持其响应。

1) 矩形三角形

为了获得这样的三角形,我们需要一个线性梯度和一个对角线方向,如从右下角、从左上角、从右下等

三-1,三-2{显示:内联块;宽度:100px;高度:100px;背景:线性渐变(到左下角,透明49.5%,红色50%);边框:1px实心;动画:更改2s线性无限交替;}.三-2{背景:线性渐变(到右上角,透明49.5%,红色50%);边框:无;}@关键帧更改{来自{宽度:100px;高度:100px;}至{高度:50px;宽度:180px;}}<div class=“tri-1”></div><div class=“tri-2”></div>

2) 等腰三角形

对于这一个,我们将需要2个像上面一样的线性梯度,每个梯度将占宽度(或高度)的一半。就像我们创建了第一个三角形的镜像。

.tri三{显示:内联块;宽度:100px;高度:100px;背景图像:线性梯度(至右下角,透明49.5%,红色50%),线性梯度(至左下方,透明49.5%,红色50%);背景大小:50.3%100%;/*我使用一个略大于50%的值,以避免两个梯度之间的小间隙*/背景位置:左、右;背景重复:无重复;动画:更改2s线性无限交替;}@关键帧更改{来自{宽度:100px;高度:100px;}至{高度:50px;宽度:180px;}}<div class=“tri”></div>

3) 等边三角形

这个处理起来有点棘手,因为我们需要保持渐变的高度和宽度之间的关系。我们将使用与上述相同的三角形,但为了将等腰三角形转换为等边三角形,我们将使计算更加复杂。

为了方便起见,我们将考虑到div的宽度是已知的,并且高度足够大,可以在内部绘制三角形(height>=width)。

我们有两个梯度g1和g2,蓝色线是divw的宽度,每个梯度都有50%的宽度(w/2),三角形的每一边都等于w。绿色线是两个梯度hg的高度,我们可以很容易地得到以下公式:

(w/2)²+hg²=w²--->hg=(sqrt(3)/2)*w--->hg=0.866*w

我们可以依靠calc()进行计算并获得所需的结果:

.tri三{--w: 100像素;宽度:var(--w);高度:100px;显示:内联块;背景图像:线性梯度(至右下角,透明49.5%,红色50%),线性梯度(至左下方,透明49.5%,红色50%);背景大小:calc(var(--w)/2+0.5px)calc(0.866*var(--w));背景位置:左下、右下;背景重复:无重复;}<div class=“tri”></div><div class=“tri”style=“--w:80px”></div><div class=“tri”style=“--w:50px”></div>

另一种方法是控制div的高度,并保持渐变的语法简单:

.tri三{--w: 100像素;宽度:var(--w);高度:计算值(0.866*var(--w));显示:内联块;背景:线性梯度(至右下,透明49.8%,红色50%)向左,线性梯度(至左下,透明49.8%,红色50%);背景尺寸:50.2%100%;背景重复:无重复;}<div class=“tri”></div><div class=“tri”style=“--w:80px”></div><div class=“tri”style=“--w:50px”></div>

4) 随机三角形

要获得一个随机三角形,很容易,因为我们只需要删除每个三角形的50%的条件,但我们应该保持两个条件(两个条件都应该具有相同的高度,两个宽度的总和应该是100%)。

.三-1{宽度:100px;高度:100px;显示:内联块;背景图像:线性梯度(至右下角,透明50%,红色0),线性梯度(至左下角,透明50%,红色0);背景尺寸:20%60%,80%-60%;背景位置:左下、右下;背景重复:无重复;}<div class=“tri-1”></div>

但如果我们想为每一侧定义一个值呢?我们只需要再次计算!

让我们将hg1和hg2定义为渐变的高度(两者都等于红线),然后将wg1和wg2定义为梯度的宽度(wg1+wg2=a)。我不会详细说明计算,但在最后我们将得到:

wg2 = (a²+c²-b²)/(2a)
wg1 = a - wg2
hg1 = hg2 = sqrt(b² - wg1²) = sqrt(c² - wg2²)

现在我们已经达到了CSS的极限,因为即使使用calc(),我们也无法实现这一点,所以我们只需要手动收集最终结果并将其作为固定大小使用:

.tri三{--wg1:20px;--wg2:60px;--汞:30像素;宽度:calc(var(--wg1)+var(--wg2));高度:100px;显示:内联块;背景图像:线性梯度(至右下角,透明49.5%,红色50%),线性梯度(至左下方,透明49.5%,红色50%);背景大小:var(--wg1)var(--hg),var(--wg2)var(-hg);背景位置:左下、右下;背景重复:无重复;}<div class=“tri”></div><div class=“tri”style=“--wg1:80px;--wg2:60px;--hg:100px;”></div>

奖金

我们不应该忘记,我们也可以应用旋转和/或倾斜,我们有更多的选择来获得更多的三角形:

.tri三{--wg1:20px;--wg2:60px;--汞:30像素;宽度:calc(var(--wg1)+var(--wg2)-0.5px);高度:100px;显示:内联块;背景图像:线性梯度(至右下角,透明49%,红色50%),线性梯度(至左下角,透明49%,红色50%);背景大小:var(--wg1)var(--hg),var(--wg2)var(-hg);背景位置:左下、右下;背景重复:无重复;}<div class=“tri”></div><div class=“tri”style=“transform:偏斜Y(25deg)”></div><div class=“tri”style=“--wg1:80px;--wg2:60px;--hg:100px;”></div><div class=“tri”style=“--wg1:80px;--wg2:60px;--hg:100px;transform:rotate(20deg)”></div>

当然,我们应该记住SVG解决方案,它在某些情况下更适合:

svg公司{宽度:100px;高度:100px;}多边形{填充:红色;}<svg viewBox=“0 0 100 100”><多边形点=“0100 0,0 100100”/></svg><svg viewBox=“0 0 100 100”><多边形点=“0100 50,0 100100”/></svg><svg viewBox=“0 0 100 100”><多边形点=“0100 50,23 100100”/></svg><svg viewBox=“0 0 100 100”><多边形点=“20,60 50,43 80100”/></svg>

剪辑路径对我来说效果最好-适用于具有和不具有固定尺寸的div/容器:

.triangleContainer{
    position: relative;
    width: 500px;
    height: 500px;
}

.triangleContainer::before{
    content: "";        
    position: absolute;
    background:blue;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    clip-path: polygon(50% 0, 0 100%, 100% 100%);
}

这是一个老问题,但我认为值得分享如何使用这种三角形技术创建箭头。

步骤1:

让我们创建两个三角形,对于第二个,我们将使用:after伪类,并将其放置在另一个的正下方:

.箭头{宽度:0;高度:0;边框半径:50px;显示:内联块;位置:相对;}.arrow:在之后{内容:“”;宽度:0;高度:0;位置:绝对;}.向上箭头{左边框:50px实心透明;右边框:50px实心透明;边框底部:50px实心#333;}.向上箭头:之后{顶部:5px;左边框:50px实心透明;右边框:50px实心透明;边框底部:50px实心#ccc;右:-50px;}<div class=“arrow arrow up”></div>

步骤2

现在,我们只需将第二个三角形的主要边界颜色设置为与背景相同的颜色:

.箭头{宽度:0;高度:0;边框半径:50px;显示:内联块;位置:相对;}.arrow:在之后{内容:“”;宽度:0;高度:0;位置:绝对;}.向上箭头{左边框:50px实心透明;右边框:50px实心透明;边框底部:50px实心#333;}.向上箭头:之后{顶部:5px;左边框:50px实心透明;右边框:50px实心透明;边框底部:50px实心#fff;右:-50px;}<div class=“arrow arrow up”></div>

摆弄所有箭头:http://jsfiddle.net/tomsarduy/r0zksgeu/