web-dev-qa-db-fra.com

Dessiner des lignes angulaires en CSS

Ce que j'essaye de faire est simple, mais je n'arrive pas à comprendre comment le faire.

Comme vous pouvez le voir sur mon image, il y a quelques lignes rouges qui traversent le bas, puis se plient vers le haut près du côté droit.

Existe-t-il un moyen en CSS de tracer une ligne comme celle-ci?

example showing lines

13
Sherwin Flight

Vous pouvez créer des lignes angulaires en CSS en utilisant des transformations de biais (transform: skew(Xdeg)). Voici un exemple d'extrait:

.shape {
  height: 50px;
  width: 200px;
  border-bottom: 2px solid red;
  border-right: 2px solid red;
  -moz-transform: skew(-45deg);
  -webkit-transform: skew(-45deg);
  transform: skew(-45deg);
}
<div class="shape"></div>

Une double ligne avec une au-dessus de la zone de contenu et une derrière peut également être effectuée en utilisant un seul élément (et quelques pseudos) comme dans l'extrait ci-dessous:

.shape:before {
  position: absolute;
  bottom: -5px;
  left: -5px;
  content: '';
  height: 50px;
  width: 100%;
  border-bottom: 3px solid red;
  border-right: 4px solid red;
  -webkit-transform: skew(-45deg);
  -moz-transform: skew(-45deg);
  transform: skew(-45deg);
}
.shape:after {
  position: absolute;
  content: '';
  bottom: -10px;
  left: 0px;
  height: 55px;
  width: 100%;
  border-bottom: 3px solid red;
  border-right: 4px solid red;
  -webkit-transform: skew(-45deg);
  -moz-transform: skew(-45deg);
  transform: skew(-45deg);
  z-index: -1;
}
.shape {
  position: relative;
  height: 80px;
  width: 400px;
  background: whitesmoke;
}
<div class="shape">
  Some text that goes within the element...
</div>
29
Harry