Создание адаптивного скошенного фона с помощью CSS
Я пытаюсь создать перекос фона на моем сайте. Все блоки будут иметь скошенную верхнюю и нижнюю линию (как параллелограмм).
Пробовал с помощью CSS:
transform: skewY(-30deg);
но он не работает быстро. Есть мысли о хорошей практике?
2 ответа
Решение
Вот начало, оба очень легкие
Использование псевдоэлемента
.wrapper div.skew::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 120vw;
height: 100%;
transform: translate(-50%, -50%) rotate(-30deg) skew(-30deg);
background: lightgray;
z-index: -1;
}
.wrapper {
overflow: hidden;
}
.wrapper div {
position: relative;
padding: 50px;
border: 1px dashed gray;
text-align: center;
}
.wrapper div.skew::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 120vw;
height: 100%;
transform: translate(-50%, -50%) rotate(-30deg) skew(-30deg);
background: lightgray;
z-index: -1;
}
<div class="wrapper">
<div>
Some text
</div>
<div class="skew">
Some text
</div>
<div>
Some text
</div>
</div>
С помощью linear-gradient
html {
background: linear-gradient(
-30deg,
transparent 40%,
#bbb 40%,
#bbb 60%,
transparent 60%);
}
html {
background: linear-gradient(
-30deg,
transparent 40%,
#bbb 40%,
#bbb 60%,
transparent 60%);
}
div {
position: relative;
padding: 50px;
border: 1px dashed gray;
text-align: center;
}
<div>
Some text
</div>
<div class="skew">
Some text
</div>
<div>
Some text
</div>
Мне очень нравится метод сгенерированного css контента Джереми Фрэнка - он даже предлагает классный SASS-Mixin в своей статье: https://www.viget.com/articles/angled-edges-with-css-masks-and-transforms
Я использую этот вариант много:
/*
* Angled-edges
*/
@mixin angle($pseudo, $flip: false, $use-background-color: false, $angle: 3deg) {
// $pseudo: before, after, both
@if $pseudo == 'before' or $pseudo == 'after' or $pseudo == 'both' {
position: relative;
z-index: 1;
$selector: if($pseudo == 'both', '&:before,&:after', '&:#{$pseudo}');
#{$selector} {
@if $use-background-color {
background: $color__background-body;
} @else {
background: inherit;
}
content: '';
display: block;
height: 50%;
left: 0;
position: absolute;
right: 0;
z-index: -1;
-webkit-backface-visibility: hidden;
}
@if $pseudo == 'before' {
#{$selector} {
top: 0;
@if $flip {
transform: skewY($angle * -1);
transform-origin: 0 0;
} @else {
transform: skewY($angle);
transform-origin: 100% 0;
}
}
}
@if $pseudo == 'after' {
#{$selector} {
bottom: 0;
@if $flip {
transform: skewY($angle);
transform-origin: 0 100%;
} @else {
transform: skewY($angle * -1);
transform-origin: 100%;
}
}
}
@if $pseudo == 'both' {
&:before {
top: 0;
@if $flip {
transform: skewY($angle * -1);
transform-origin: 0 0;
} @else {
transform: skewY($angle);
transform-origin: 100% 0;
}
}
&:after {
bottom: 0;
@if $flip {
transform: skewY($angle);
transform-origin: 0 0;
} @else {
transform: skewY($angle * -1);
transform-origin: 100%;
}
}
}
}
}