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

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

Мы добьемся этого, сделав текст прозрачным, поместив фоновое оформление текста с помощью 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, мы могли бы либо оставить черный цвет текста по умолчанию, либо установить другой цвет.

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

Заключение

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

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

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

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

2024 год стал еще одним удивительным годом для CSS!
2024 год стал еще одним удивительным годом для CSS!

Переходы между документами и анимация при прокрутке позволяют добавить больше интерактивности в ваши приложения с помощью нескольких строк CSS. Теперь вы можете анимировать height: auto;, стилизовать полосы прокрутки и изменять размер текстовых полей в соответствии с их содержимым.

Несколько примеров параллакса на CSS, которые можно использовать в своих проектах
Несколько примеров параллакса на CSS, которые можно использовать в своих проектах

Откройте для себя прокручиваемый холст, на котором элементы перемещаются с изяществом — добро пожаловать в искусство параллакса CSS.

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

Градиентная обводка блока на CSS
Градиентная обводка блока на CSS

Как сделать красивую градиентную обводку блока на одном только CSS? Для этого мы сделаем следующее:

1. Создадим div.linear-gradient с градиентным фоном;

2. Создадим внутренний блок div с небольшим отступом.

CSS анимация обводки блоков
CSS анимация обводки блоков

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

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

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

QRcode

2010-2025 © Веб студия iNikSite.ru (г. Подольск). Все права сохранены.

Цены на сайте носят ознакомительный характер и не являются публичной офертой! Просим уточнять цены при отправке заявки в нашу компанию. У нас действуют специальные предложения и скидки на различные варианты исполнения заказа и 100% предоплату!

Мы используем файлы cookie. Они помогают улучшить ваше взаимодействие с сайтом.