company_banner

30 секунд CSS

https://atomiks.github.io/30-seconds-of-css/
  • Перевод
  • Tutorial


Предлагаем вашему вниманию коллекцию полезных CSS-сниппетов, в которых вы можете разобраться за 30 секунд, а то и быстрее.


Clearfix


Позволяет элементу автоматически применять clear к своим дочерним элементам.


Примечание: полезно только в том случае, если вы всё ещё используете float при создании макетов. Рассмотрите возможность перейти на более современные подходы с применением flexbox или сетки.


HTML


<div class="clearfix">
  <div class="floated">float a</div>
  <div class="floated">float b</div>
  <div class="floated">float c</div>
</div>

CSS


.clearfix::after {
  content: "";
  display: block;
  clear: both;
}
.floated {
  float: left;
}

Пример



Объяснение


  1. .clearfix::after определяет псевдоэлемент.
  2. content: '' позволяет псевдоэлементу влиять на макет.
  3. clear: both означает, что в рамках одного блочного отформатированного контекста левая, или правая, или обе стороны элемента не могут примыкать к элементам, к которым ранее применено float.

Поддержка в браузерах


99+ %


Подводных камней нет.


Постоянное соотношение ширины к высоте


Если у элемента изменяется ширина, то и высота динамически меняется пропорционально, с заданным коэффициентом (то есть отношение ширины к высоте остаётся неизменным).


HTML


<div class="constant-width-to-height-ratio"></div>

CSS


.constant-width-to-height-ratio {
  background: #333;
  width: 50%;
  padding-top: 50%;
}

Объяснение


padding-top и padding-bottom могут использоваться в качестве альтернативы height, поскольку процентное значение высоты элемента становится процентным значением ширины. То есть 50% означает, что высота элемента будет составлять 50 % от ширины. В результате соотношение сторон не меняется.


Поддержка в браузерах


99+ %


padding-top смещает всё содержимое на дно элемента.


Кастомное выделение текста


Изменяет стиль выделения текста.


HTML


<p class="custom-text-selection">Select some of this text.</p>

CSS


.custom-text-selection::selection {
  background: red;
  color: white;
}

Пример



Объяснение


::selection определяет в элементе псевдоселектор, чтобы применять стиль к тексту, когда он выделен.


Поддержка в браузерах


84,6 %


Эта фича пока отсутствует в спецификациях, для её полной поддержки нужно использовать префиксы.



Переменные плавности анимации


Переменные, которые можно повторно использовать для свойств transition-timing-function, дают больше возможностей по сравнению со встроенными ease, ease-in, ease-out и ease-in-out.


HTML


<div class="easing-variables"></div>

CSS


:root {
  --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
  --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
  --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
  --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
  --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
  --ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
  --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
}
.easing-variables {
  width: 50px;
  height: 50px;
  background: #333;
  transition: transform 1s var(--ease-out-quart);
}
.easing-variables:hover {
  transform: rotate(45deg);
}

Пример



Объяснение


Переменные, объявленные глобально вне псевдокласса :root CSS, которые совпадают с корневым элементом дерева документа. В HTML :root соответствует элементу и идентичен селектору html, кроме лишь того, что его специфика выше.

Поддержка в браузерах


87,2 %


Подводных камней нет.



Вдавленный текст


Создаёт эффект вдавленного, или выгравированного на фоне текста.


HTML


<p class="etched-text">I appear etched into the background.</p>

CSS


.etched-text {
  text-shadow: 0 2px white;
  font-size: 1.5rem;
  font-weight: bold;
  color: #b8bec5;
}

Пример



Объяснение


text-shadow: 0 2px white создаёт белую тень со смещением 0px по горизонтали и 2px по вертикали от исходной позиции. Фон должен быть темнее тени, а текст — слегка выцветшим, чтобы он выглядел вдавленным/выгравированным на фоне.


Поддержка в браузерах


97,9 %


Подводных камней нет.



Градиентный текст


Делает градиентную заливку текста.


HTML


<p class="gradient-text">Gradient text</p>

CSS


.gradient-text {
  background: -webkit-linear-gradient(pink, red);
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
}

Пример



Объяснение


  1. background: -webkit-linear-gradient(...) делает у текстового элемента градиентный фон.
  2. webkit-text-fill-color: transparent заполняет текст прозрачным цветом.
  3. webkit-background-clip: text закрепляет фон с текстом, заливает текст градиентным фоном в качестве цвета.

Поддержка в браузерах


90,7 %
️ Использует нестандартные свойства.



Тонкая рамка


Делает вокруг элемента рамку, по толщине эквивалентную одному нативному пикселю устройства, очень резкую, не размытую.


HTML


<div class="hairline-border">text</div>

CSS


.hairline-border {
  box-shadow: 0 0 0 1px;
}
@media (min-resolution: 2dppx) {
  .hairline-border {
    box-shadow: 0 0 0 0.5px;
  }
}
@media (min-resolution: 3dppx) {
  .hairline-border {
    box-shadow: 0 0 0 0.33333333px;
  }
}
@media (min-resolution: 4dppx) {
  .hairline-border {
    box-shadow: 0 0 0 0.25px;
  }
}

Пример



Объяснение


  1. Box-shadow при использовании спреда (spread) добавляет псевдорамку, которая может использовать субпиксели*.
  2. Применяйте @media (min-resolution: ...) для проверки соотношения логических и физических пикселей на устройстве (device pixel ratio) (1ddpx эквивалентно 96 DPI), задайте спред box-shadow равным 1 / dppx.

Поддержка в браузерах


95 %


️Для полной поддержки нужен альтернативный синтаксис и проверка JavaScript юзер-агента.



Горизонтальное и вертикальное центрирование


Центрирует дочерний элемент по вертикали и горизонтали внутри родительского элемента.


HTML


<div class="horizontal-and-vertical-centering">
  <div class="child"></div>
</div>

CSS


.horizontal-and-vertical-centering {
  display: flex;
  justify-content: center;
  align-items: center;
}

Пример



Объяснение


  1. display: flex включает flexbox.
  2. justify-content: center центрирует дочерний элемент по горизонтали.
  3. align-items: center центрирует дочерний элемент по вертикали.

Поддержка в браузерах


97,8 %


️Для полной поддержки нужны префиксы.



Градиентное отслеживание курсора мыши (требуется JavaScript)


При наведении курсор сопровождается градиентным эффектом.


HTML


<button class="mouse-cursor-gradient-tracking">
  <span>Hover me</span>
</button>

CSS


.mouse-cursor-gradient-tracking {
  position: relative;
  background: #2379f7;
  padding: 0.5rem 1rem;
  font-size: 1.2rem;
  border: none;
  color: white;
  cursor: pointer;
  outline: none;
  overflow: hidden;
}
.mouse-cursor-gradient-tracking span {
  position: relative;
}
.mouse-cursor-gradient-tracking::before {
  --size: 0;
  content: '';
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--size);
  height: var(--size);
  background: radial-gradient(circle closest-side, pink, transparent);
  transform: translate(-50%, -50%);
  transition: width .2s ease, height .2s ease;
}
.mouse-cursor-gradient-tracking:hover::before {
  --size: 200px;
}
JavaScript
var btn = document.querySelector('.mouse-cursor-gradient-tracking')
btn.onmousemove = function (e) {
  var x = e.pageX - btn.offsetLeft
  var y = e.pageY - btn.offsetTop
  btn.style.setProperty('--x', x + 'px')
  btn.style.setProperty('--y', y + 'px')
}

Пример



Объяснение


  1. ::before определяет псевдоэлемент
  2. --size, --x, --y являются набором пользовательских CSS-свойств
  3. background: radial-gradient(circle closest-side, pink, transparent); определяет градиент
  4. --size: 200px; показывают градиент при наведении
  5. btn.style.setProperty('--x', x + 'px') и btn.style.setProperty('--y', y + 'px') определяют положение блока с градиентом относительно контейнера

Примечание. Если родительский элемент позиционирован относительно содержимого (position: relative), то придётся также вычитать и его смещение.


var x = e.pageX - btn.offsetLeft - btn.offsetParent.offsetLeft
var y = e.pageY - btn.offsetTop - btn.offsetParent.offsetTop

Поддержка в браузерах


87,2 %


️Требуется JavaScript.



Градиент при избыточной прокрутке


Добавляет градиент к избыточному элементу, чтобы лучше отображать контент, который можно прокрутить.


HTML


<div class="overflow-scroll-gradient">
  <div class="overflow-scroll-gradient__scroller">
    Content to be scrolled
  </div>
</div>
CSS
.overflow-scroll-gradient {
  position: relative;
}
.overflow-scroll-gradient::after {
  content: '';
  position: absolute;
  bottom: 0;
  width: 300px;
  height: 25px;
  background: linear-gradient(rgba(255, 255, 255, 0.001), white); /* transparent keyword is broken in Safari */
}
.overflow-scroll-gradient__scroller {
  overflow-y: scroll;
  background: white;
  width: 300px;
  height: 250px;
  padding: 15px 0;
  line-height: 1.2;
  text-align: center;
}

Пример



Объяснение


  1. position: relative применительно к родительскому элементу задаёт декартово позиционирование псевдоэлементов.
  2. ::after определяет псевдоэлемент.
  3. background-image: linear-gradient(...) добавляет линейный градиент от прозрачного к белому (сверху вниз).
  4. position: absolute берёт псевдоэлемент из потока документа и позиционирует его относительно родительского элемента.
  5. width: 300px задаёт размер прокручиваемого элемента (дочернего по отношению к родительскому, содержащему псевдоэлемент).
  6. height: 25px — это высота градиентного псевдоэлемента, она должна быть относительно небольшой.
  7. bottom: 0 позиционирует псевдоэлемент по нижней границе родительского элемента.

Поддержка в браузерах


94,8 %


Подводных камней нет.



Выдвигающееся (popout) меню


При наведении курсора выдвигается интерактивное меню.


HTML


<div class="reference">
  <div class="popout-menu">
    Popout menu
  </div>
</div>

CSS


.reference {
  position: relative;
}
.popout-menu {
  position: absolute;
  visibility: hidden;
  left: 100%;
}
.reference:hover > .popout-menu {
  visibility: visible;
}

Пример



Объяснение


  1. position: relative для референсного родительского элемента устанавливает декартово позиционирование дочернего элемента.
  2. position: absolute берёт из потока документа выдвигающееся меню и позиционирует его относительно родительского элемента.
  3. left: 100% целиком выводит меню слева от родительского элемента.
  4. visibility: hidden изначально скрывает меню и разрешает переходы (в отличие от display: none).
  5. .reference:hover > .popout-menu означает, что, когда курсор мыши проходит над .reference, немедленно выбираются дочерние элементы с классом .popout-menu, а их видимость (visibility) меняется на visible, в результате мы видим меню.

Поддержка в браузерах


99+ %


Подводных камней нет.


Красивое подчёркивание текста


Более симпатичная альтернатива text-decoration: underline, когда линия не пересекает нижние выносные элементы букв. Нативно реализовано в качестве text-decoration-skip-ink: auto, но при этом у нас становится меньше возможностей управлять подчёркиванием.


HTML


<p class="pretty-text-underline">Pretty text underline without clipping descending letters.</p>

CSS


.pretty-text-underline {
  display: inline;
  font-size: 1.25rem;
  text-shadow: 1px 1px 0 #f5f6f9,
    -1px 1px 0 #f5f6f9,
    -1px -1px 0 #f5f6f9,
    1px -1px 0 #f5f6f9;
  background-image: linear-gradient(90deg, currentColor 100%, transparent 100%);
  background-position: 0 1.04em;
  background-repeat: repeat-x;
  background-size: 1px 1px;
}
.pretty-text-underline::selection {
  background-color: rgba(0, 150, 255, 0.3);
  text-shadow: none;
}

Пример



Объяснение


  1. text-shadow: ... имеет четыре значения со сдвигами, покрывающие зону 4 × 4 пикселя, чтобы у подчёркивания была «толстая» тень, накрывающая линию в местах пересечения выносных элементов букв. Используйте цвет фона. Для крупных шрифтов задавайте зону большего размера
  2. background-image: linear-gradient(...) создаёт 90-градусный градиент текущего цвета текста (currentColor).
  3. Свойства background-* задают внизу градиент размером 1 × 1 px и повторяют его по оси Х.
  4. Псевдоселектор ::selection отвечает за то, чтобы тень текста не накладывалась на текстовое выделение.

Поддержка в браузерах


94,8 %


Для работы ::selection в Firefox необходимы префиксы



Разделитель


Использует SVG-форму для разделения двух разных блоков, чтобы получилось визуально более интересное отображение на экране по сравнению со стандартным горизонтальным разделением.


HTML


<div class="shape-separator"></div>

CSS


.shape-separator {
  position: relative;
  height: 48px;
}
.shape-separator::after {
  content: '';
  background-image: url();
  position: absolute;
  width: 100%;
  height: 24px;
  bottom: 0;
}

Пример



Объяснение


  1. position: relative задаёт для элемента декартово позиционирование псевдоэлементов.
  2. ::after задаёт псевдоэлемент.
  3. background-image: url(...) добавляет в качестве фонового изображения псевдоэлемента SVG-форму (треугольник 24 × 24 в формате base64), которая по умолчанию многократно повторяется. Она должна быть того же цвета, что и отделяемый блок.
  4. position: absolute берёт псевдоэлемент из потока документа и позиционирует его относительно родительского элемента.
  5. width: 100% растягивает элемент по всей ширине его родительского элемента.
  6. height: 24px задаёт такую же высоту, как и у SVG-формы.
  7. bottom: 0 позиционирует псевдоэлемент внизу родительского элемента.

Поддержка в браузерах


98 %


Подводных камней нет.



Стек системных шрифтов


Использует нативные шрифты операционной системы, чтобы приложение выглядело как можно более естественно.


HTML


<p class="system-font-stack">This text uses the system font.</p>

CSS


.system-font-stack {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", Helvetica, Arial, sans-serif;
}

Пример



Объяснение


Браузер ищет каждый из нижеперечисленных шрифтов. Если первый шрифт недоступен — ищет второй, если он тоже недоступен — ищет третий и т. д.


  1. -apple-system — шрифт San Francisco, используемый в iOS и macOS (но не в Chrome).
  2. BlinkMacSystemFont — шрифт San Francisco, используемый в macOS Chrome.
  3. Segoe UI используется в Windows 10.
  4. Roboto — в Android.
  5. Oxygen-Sans — в GNU + Linux.
  6. Ubuntu — в Linux.
  7. "Helvetica Neue" и Helvetica — в macOS 10.10 и ниже (взят в кавычки, потому что в названии есть пробел).
  8. Arial широко поддерживается всеми ОС.
  9. sans-serif — запасной шрифт без засечек, используется, если все вышеперечисленные недоступны.

Поддержка в браузерах


99+ %


Подводных камней нет.


Треугольник


С помощью чистого CSS создаёт треугольную форму.


HTML


<div class="triangle"></div>

CSS


.triangle {
  width: 0;
  height: 0;
  border-top: 20px solid #333;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
}

Пример



Объяснение


Подробное объяснение.


Цвет границы — это цвет самого треугольника. Сторона, в которую обращена вершина треугольника, противоположна свойству border-*. Например, border-top означает, что «стрелка» указывает вниз.


Поэкспериментируйте со значениями px, чтобы изменить пропорции треугольника.


Поддержка в браузерах


99+ %


Подводных камней нет.


Обрезание текста


Если текст длиннее одной строки, он обрежется, а в конце будет подставлено многоточие.


HTML


<p class="truncate-text">If I exceed one line's width, I will be truncated.</p>

CSS


.truncate-text {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

Пример



Объяснение


  1. overflow: hidden не даёт тексту выйти за пределы размерностей (для блока это 100 % ширины и автоматическая высота).
  2. white-space: nowrap не даёт тексту занять по высоте одну строку.
  3. text-overflow: ellipsis делает так, что когда текст достигает заданных размеров, то в конце вставляется многоточие.

Поддержка в браузерах


98,1 %


Работает только с однострочными элементами


Mail.Ru Group 550,88
Строим Интернет
Поделиться публикацией
Похожие публикации
Комментарии 52
  • 0
    А можно немножко подробней, от чего берется % в поддержке браузерами?
  • 0
    Уберите приписки «подводных камней нет» — как минимум в некоторых пунктах они не соответствуют действительности, а потому бесполезны.
    • 0

      Это перевод. Но претензию можно (и нужно) адресовать оригиналу. В принципе, проект опенсорсный и общая идея хорошая, надеюсь, общими усилиями со временем допилим!


      А пока что можно вносить уточнения тут в комментариях. Например, по подводным камням многострадального «клиарфикса» и его «друзей» осмелюсь нескромно предложить этот наглядный пример и сводную таблицу таких «камней»...

      • 0
        Не думаю что они так уж бесполезны. Верно я понял, что они указывают на (не)использование префиксов?
        • 0

          Не только. Они, похоже, имеют в виду, что это не что-то нестандартное. Но хак (в случае того же многострадального клиарфикса, например) от стандартности применяемых средств хаком быть не перестает, и может аукнуться, например, если контейнеру с на всякий случай стоявшим клиарфиксом, кто-нибудь захочет задать flex или grid...

      • +1
        А например, сниппет про
        Выдвигающееся (popout) меню
        просто вреден с точки зрения доступности контента: пользователи без мышки (например, владельцы смартфонов и планшетов) просто никак этот контент не увидят.
        • +1
          Раз на элемент нужно наводить — значит это кнопка или ссылка.
          Можно использовать не только :hover, но и :focus для отображения подсказки.
          • 0
            до тех пор полезно пока градиентный квадрат не упрется в правую часть окна. И подсказка видна не будет. Все же title=«подсказка» лучше для этого подходит. Этот атрибут «видит» границы и не уходит в неведомую даль
          • 0
            В нём также не хватает задержки сворачивания. Без неё сниппет просто ужасен: стоит дрогнуть курсору, и весь путь приходится начинать сначала. Особенно если меню многоуровневое, а пункты — небольшой высоты.
          • 0
            Согласен, ужасно. Не говоря уже, что скрытый визуально элемент будет все-равно влиять на вёрстку, отодвигая границу страницы, в случае его нахождения у оной. display: none; во многих случаях предпочтительнее.
          • 0
            > «Helvetica Neue»… взят в кавычки, потому что в названии есть пробел.

            В кавычки не нужно брать…
            • +1

              А за что минус влепили? Стандарт ведь кавычек действительно не требует...


              Имена шрифтов кроме общих семейств (т.е. ‘serif’, ‘sans-serif’, ‘cursive’, ‘fantasy’, и ‘monospace’) должны быть либо в кавычках как строки, либо без кавычек как последовательность из одного и более идентификаторов.

              … хотя, правда, и рекомендует ставить их «для ясности»:


              Во избежание ошибок в экранировании, рекомендуется брать в кавычки имена шрифтов, содержащие пробелы, цифры и знаки пунктуации кроме дефиса
            • 0

              Опять эти треугольники бордюрами. SVG ещё не изобрели?

              • 0
                КМК бордюрами компактнее выйдет.
              • +1
                Какой сейчас год? Сейчас бы использовать float и clearfix…
                • 0

                  Видел я недавно ребят, которые пилили дорогущие проекты при этом верстали флоатами, а о clearfix даже не знали, потом писали костыли отступами, что-бы это обойти, им как минимум будет полезно.

              • 0
                Спасибо за перевод!
                • +1
                  Устаревшие весьма приемы, но для новичков может быть полезно. Хотя многое из CSS Secrets вроде взято. Ну и блиин..2018 год… вставлять демки картинками это моветон
                  • +1
                    Иронично, что на примере «очень резкой и не размытой рамки» видно размытый бордер
                    • 0
                      Градиент при избыточной прокрутке

                      В этом примере я бы ещё добавил


                      .overflow-scroll-gradient::after {
                        …
                        pointer-events: none
                      }

                      Что бы можно было кликнуть "сквозь" псевдоэлемент.

                    • +6

                      Зачем-то закодирован SVG в base64


                      background-image: url();

                      а можно было написать так


                      background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd' clip-rule='evenodd' stroke-linejoin='round' stroke-miterlimit='1.414'><path d='M12 12l12 12H0l12-12z' fill='white'/></svg>")

                      Короче и понятнее.

                      • +3

                        …и становится видно, что атрибуты fill-rule, clip-rule, stroke-linejoin и stroke-miterlimit тут ни на что не влияют, и их можно смело выкосить.

                        • 0

                          И l12-12 можно убрать из path так как z всё равно его замкнёт.


                          <path d='M12 12l12 12H0z' fill='white'/>
                        • +2

                          Короче и понятнее, но, к сожалению, не кроссбраузернее. Но есть еще такой вариант:)

                        • 0
                          + ко всему fill можно вывести в свойства класса и манипулировать им из цсс
                          • 0
                            Насколько я помню, это менее кроссбраузерно
                            • 0
                              Хром, ФФ, Опера, Эдж точно поддерживают, только что проверил, но у меня СВГ вставлен инлайново в разметку, а стилями уже задаю цвета, хаверы и т.д. с транзишенами. Да еще и заполнение линии можно сделать анимацией.
                              • 0
                                Я не помню сейчас навскидку, но точно где-то сталкивался с проблемами. Вообще SVG — очень мутная и труднопредсказуемая штука. Её можно использовать миллионом способов и обязательно какой-то из них где-то будет косячным — это я говорю по личному опыту, хотя и не имеющему прямого отношения к обсуждаемому примеру. Помню, раньше в IE и старых Хромах имели значения даже кавычки (одиночные/двойные, экранированные/нет).
                                • 0
                                  SVG — очень мутная и труднопредсказуемая штука… раньше в IE и старых Хромах имели значения даже кавычки

                                  Да что уж там, в IE11 (можно сказать, что это почти нормальный браузер) переносы строк не в том месте могут все сломать.
                                • 0
                                  но у меня СВГ вставлен инлайново в разметку

                                  Вставленный инлайново и в стили это две большие разности по возможностям.
                                  • 0
                                    Конечно.
                                    А насчет кроссбраузерности — вот к примеру в этом сервисе iconizr.com — были явные косяки с отображением спрайта — в ФФ видно в Хроме через один, но, если через него-же взять css где запилено как в примере (только не base64) — везде был порядок в браузерах.
                              • 0

                                Если инлайново в html вставить, то да можно манипулировать свойствами svg из css. А если задать его бекграундом, как в примере, то такой фокус уже не пройдёт.

                            • +1
                              sans-serif — запасной шрифт без засечек
                              sans-serif является семейством шрифтов, но не самим шрифтом
                              • 0
                                Красивое подчёркивание текста

                                Не знаю, кому нужно подобное подчёркивание, а вот то, что при решении используется гораздо более полезное создание контура вокруг текста — на этом можно было акцентировать больше внимания. Причём контур растёт не от середины границы букв, а наружу, что делает его лучше, чем граница с помощью эффектов CSS. Правда применимость несколько ограничена из-за квадратности, с крупным кеглем результат может выглядеть неидеально.


                                background-image: url(

                                SVG — один из форматов, который отлично встраивается в data URI в CSS без base64. Экранировать нужно только кавычки (что обычно ненужно, так как снаружи и внутри можно использовать разные кавычки), символ "#" и, возможно, ещё что-то. Разбиение на строки тоже возможно. В результате можно получить полностью читаемый и редактируемый SVG внутри CSS.


                                font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", Helvetica, Arial, sans-serif;

                                С подобными выкрутасами надо быть поосторожнее, потому что у разных шрифтов могут быть разные "размерности", ну а для тех, кто пишет pre { font-family: "Courier New", sans-serif; } запасён отдельный котёл в аду. Привет, Хабр.

                                • 0
                                  Вот так, верстаешь 2-3 года, ломаешь голову, учишься разным фишками css (типа треугольников, обрезанию текста. и т.д.), а в 2018 году достаточно прочесть одну статью :D
                                  Круто, спасибо за статью!
                                  • 0

                                    Народ, не перегоняйте SVG в base64, SVG — и так текстовый формат, скорее всего вы только хуже сделаете.

                                    • 0
                                      что именно будет хуже?
                                      • 0

                                        Занимает больше места и нельзя подправить на месте.

                                    • 0
                                      Постоянное соотношение ширины к высоте
                                      «метод padding-bottom»
                                      Его описание неправильное.
                                      Проценты падинг будет получать не от самого себя а от родителя.

                                      Как вариант можно использовать псевдоэлемент:
                                      .constant-width-to-height-ratio {
                                        background: #333;
                                        width: 50%;
                                        
                                        &:before {
                                          content: '';
                                          display: block;
                                          padding-top: 50%;
                                        }
                                      }
                                      

                                      • 0
                                        В тексте все правильно написано, 50% padding будет браться от собственной ширины элемента: codepen.io/anon/pen/RQOgap

                                        В вашем случае получится прямоугольник с соотношением 2:1
                                        codepen.io/anon/pen/MQRoKL
                                        Чтобы работало правильно — надо чтобы у `::beforе` padding-top был 100%
                                        • 0
                                          50% padding не будет браться от собственной ширины, а будет ей равен.
                                          Ну я понял, здесь немного другая задача.
                                      • 0
                                        Разделитель

                                        Использует SVG-форму для разделения двух разных блоков, чтобы получилось визуально более интересное отображение на экране по сравнению со стандартным горизонтальным разделением.

                                        SVG не обязательно встраивать в CSS. Можно обойтись только HTML:


                                        <!-- Внутри HTML-файла -->
                                        <svg width="100%" height="10" xmlns="http://www.w3.org/2000/svg" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" class="sawEdge">
                                          <defs>
                                            <pattern id="sawPattern" x="50%" width="20" height="10" patternUnits="userSpaceOnUse">
                                              <path d="M 0 0 L 10 10 L 20 0 Z"/>
                                            </pattern>
                                          </defs>
                                          <rect x="0" y="0" width="100%" height="10" fill="url(#sawPattern)"/>
                                        </svg>

                                        Такой разделитель намного легче править. Плюс его можно отдельно раскрашивать через CSS:


                                        .sawEdge path {
                                          fill: purple;
                                        }

                                        Демо на CodePen. Есть подводные камни (на устройствах с высокой плотностью пикселей).

                                        Только полноправные пользователи могут оставлять комментарии. Войдите, пожалуйста.

                                        Самое читаемое