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

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

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


当前回答

如果您想将边框应用于三角形,请阅读以下内容:使用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>

其他回答

我知道这是一个旧的方法,但我想在讨论中补充一点,单独使用HTML和CSS创建三角形至少有5种不同的方法。

使用边框使用线性梯度使用圆锥梯度使用转换和溢出使用剪辑路径

我认为,除了方法3(使用圆锥曲线梯度)之外,这里已经介绍了所有内容,所以我将在这里分享:

.三角形{宽度:40px;高度:40px;背景:圆锥形梯度(50%50%,透明135度,绿色0,绿色225度,透明0);}<div class=“triangle”></div>

现在完全不同了。。。

不要忘记像html实体这样简单的解决方案,而不要使用css技巧:

&#9650;

结果:

请参见:上下三角形的HTML实体是什么?

如果您想将边框应用于三角形,请阅读以下内容:使用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>

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

步骤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/

其他人已经很好地解释了这一点。让我给你一个动画,它将快速解释这一点:http://codepen.io/chriscoyier/pen/lotjh

这里有一些代码供您使用和学习这些概念。

HTML格式:

<html>
  <body>
    <div id="border-demo">
    </div>
  </body>
</html>

CSS:

/*border-width is border thickness*/
#border-demo {
    background: gray;
    border-color: yellow blue red green;/*top right bottom left*/
    border-style: solid;
    border-width: 25px 25px 25px 25px;/*top right bottom left*/
    height: 50px;
    width: 50px;
}

玩这个,看看会发生什么。将高度和宽度设置为零。然后移除顶部边框并使左右透明,或者只需查看下面的代码以创建css三角形:

#border-demo {
    border-left: 50px solid transparent;
    border-right: 50px solid transparent;
    border-bottom: 100px solid blue;
}