There are triangular unicode characters. You could draw a triangle in SVG. But there is another way to draw a triangle on the web, involving nothing but the border property and a little CSS trickery.
Imagine an element with a thick border:
.triangle {
width: 200px;
height: 200px;
border: 10px solid black;
}
data:image/s3,"s3://crabby-images/42137/42137a807692e2dca817278959493b9bf70efae7" alt=""
Now imagine all four borders have different colors:
.triangle {
...
border-left-color: red;
border-right-color: yellowgreen;
border-top-color: orange;
border-bottom-color: rebeccapurple;
}
data:image/s3,"s3://crabby-images/a8e39/a8e39956331aef05c118818d123662d967ebe18a" alt=""
Notice how the borders meet each other at angles?
Look what happens when we collapse the element to zero width and height:
.triangle {
...
width: 0;
height: 0;
}
data:image/s3,"s3://crabby-images/6b214/6b214052839cf3a9471fedc77e2c1db63d9440c1" alt=""
If three of those borders were transparent
, we’d have a triangle!
.triangle {
...
border-left-color: transparent;
border-right-color: transparent;
border-top-color: transparent;
border-bottom-color: rebeccapurple;
}
data:image/s3,"s3://crabby-images/88c52/88c52f6802b4f9c8f74ec1bb7abd2293b43f83c3" alt=""
Nice.
This could be useful on something like a pointing bubble of text. In that case, you could add the triangle to another element via a pseudo-element. Here’s a complete example:
data:image/s3,"s3://crabby-images/4c09e/4c09ebe65c6696afe8959445da46318785cb4474" alt=""