Как добавить эффекты градиента и узоры к тексту

Как добавить эффекты градиента и узоры к тексту
Как добавить эффекты градиента и узоры к тексту
В этой статье мы покажем, как легко добавить эффекты градиента и узоры к тексту на веб-странице.

Мы добьемся этого, сделав текст прозрачным, поместив фоновое оформление текста с помощью background-image свойства и обрезав это фоновое оформление до символов текста с помощью background-clip. Несколько примеров того, что мы можем создать, изображены ниже.

Прозрачный текст и background-clip

Чтобы создать нужный эффект, мы сначала задаем цвет элемента на transparent. В приведенном ниже коде мы оформляем <h1> заголовок:

h1 {
  color: transparent;
}

Конечно, просто выполнение этого означает, что текст будет невидимым, так что одного этого недостаточно.

Следующий шаг - применить background-clip: text, который обрезает любую окраску фона или эффект, который мы размещаем на элементе, только до фактических символов текста, а не заполняет все поле целиком:

h1 {
  color: transparent;
  background-clip: text;
}

Теперь мы готовы немного поколдовать. Наш текст прозрачный, и любые фоновые эффекты, которые мы применим к нему, будут обрезаны до самого текста.

Установка фонового градиента для текста

Давайте сначала попробуем установить эффект градиента для текста нашего заголовка:

h1 {
  color: transparent;
  background-clip: text;
  background-image: linear-gradient(to right, #218bff, #c084fc, #db2777);
}

Здесь мы установили градиент слева направо, который будет охватывать текст заголовка. Результат показан ручкой ниже.

Мы могли бы попробовать бесконечное количество вариантов, таких как разные цвета, изменение направления градиента, создание узоров градиента и так далее.

Давайте попробуем другой пример, на этот раз создав узор в полоску:

h1 {
  color: transparent;
  background-clip: text;
  background-image: repeating-linear-gradient(-57deg, #218bff, #218bff 3px, #c084fc 3px, #c084fc 6px);
}

Результат показан ниже.

Вот еще один пример, использующий более сложный узор. Я также добавилtext-stroke, чтобы придать буквам немного больше четкости.

Установка фонового изображения для текста

Кроме эффектов градиента, мы также можем использовать свойство background-image для применения реальных изображений к тексту. Это может быть любое изображение, но давайте попробуем изображение, содержащее повторяющийся узор. Вот изображение, которое мы будем использовать.

Мы можем применить изображение узора в качестве фона следующим образом:

h1 {
  color: transparent;
  background-clip: text;
  background-image: url(pattern.jpg);
  background-size: contain;
}

Мы добавили background-size: contain, чтобы фоновое изображение красиво вписывалось в текст. Существуют различные параметры изменения размера, которые помогут вам делать практически все, что угодно, с фоновыми изображениями!

Результат показан ниже.

Просто для развлечения, вот еще один пример с другим фоновым изображением. В этом примере вместо text-stroke мы использовали filter: drop-shadow() для улучшения текста.

background-image против background

Возможно, вы заметили, что в приведенных выше примерах мы использовали background-image свойство, а не background сокращение. Оба варианта работают нормально, но при использовании background есть одна ошибка. Вам нужно сначала объявить его, перед background-clip. В противном случае background свойство сбрасывается background-clip до значения по умолчанию border-box, и эффект не работает.

Например, это работает:

color: transparent;
background: linear-gradient(to right, #3b82f6, #c084fc, #db2777);
background-clip: text;

Это не удастся:

color: transparent;
background-clip: text;
background: linear-gradient(to right, #3b82f6, #c084fc, #db2777);

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

Браузерная поддержка color: transparent и background-clip: text существует уже долгое время, но в некоторых браузерах по-прежнему требуются префиксы поставщика. Вы заметите, что в приведенных выше блоках кода мы фактически использовали -webkit- префикс поставщика для Edge и Chrome:

-webkit-background-clip: text; /* Edge, Chrome */
background-clip: text; /* Safari, FF */

Если вы просматриваете демо-версии в Edge и Chrome без префикса поставщика, эффект не срабатывает.

Соображения о доступности

Всегда полезно помнить о том, что может произойти, если используемая нами функция CSS не поддерживается ни одним браузером. Например, если мы установим цвет текста равным transparent, но браузер не поддерживает background-clip: text;, пользователь этого браузера не сможет прочитать наш текст. (Фон будет заполнять все текстовое поле, а не ограничиваться символами текста.)

Чтобы избежать этого, мы могли бы поместить наши необычные эффекты в @supports блок, который проверяет поддержку background-clip:

@supports (background-clip: text) or (-webkit-background-clip: text) {
  h1 {
    /* styles here */
  }
}

Для браузеров, которые не поддерживают background-clip, мы могли бы либо оставить черный цвет текста по умолчанию, либо установить другой цвет.

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

Заключение

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

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

Понравилась статья?
Будем признательны, если поделитесь в соцсетях или мессенджерах, а также присоединитесь к нашей группе Вконтакте. Будет интересно!

Другие статьи по теме:

Бесплатный ФРОНТЭНД
Бесплатный ФРОНТЭНД
Представляю вашему вниманию бесплатные неоновые эффекты для текста на CSS...
Анимированные ссылки
Анимированные ссылки
Создание эффектов наведения ссылок CSS может добавить немного изюминки на скучную веб-страницу. Если вы когда-либо оказывались в тупике, пытаясь создать эффект плавного наведения, у меня есть шесть CSS-эффектов, которые вы можете взять и использовать для своего следующего проекта.
HOSTCMS v.6. Красивое горизонтальное выпадающее меню на CSS
HOSTCMS v.6. Красивое горизонтальное выпадающее меню на CSS

Меню адаптированно к использованию на сайтах под администрированием редакции HostCMS v.5 для вывода элементов каталога товаров. В выпадающем меню также выводится изображение подгруппы.

Как создать пользовательский ползунок диапазона с помощью CSS
Как создать пользовательский ползунок диапазона с помощью CSS

Ползунки диапазона (<input type="range">) позволяют пользователям выбирать значение в пределах заданного диапазона, предоставляя альтернативные типы ввода, такие как <input type="number">.

Как использовать свойства CSS object-fit и object-position
Как использовать свойства CSS object-fit и object-position

Существует множество вариантов для определения размера и расположения фоновых изображений с помощью CSS. В этой статье мы рассмотрим, как использовать object-fit для размещения изображений на определенном пространстве и как использовать object-position для правильного позиционирования в этом пространстве.

Понимание HTML5 и CSS3 для веб-дизайна
Понимание HTML5 и CSS3 для веб-дизайна

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

Мы используем файлы cookie и другие аналитичекие данные. Они помогают нам улучшить ваше взаимодействие с сайтом. Оставаясь на сайте, вы даете согласие на обработку пользовательских данных. Положение об использовании cookie