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

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

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


Анимация CSS Grid. Как сделать + примеры
Анимация CSS Grid. Как сделать + примеры
Рады пролить свет на тот факт, что CSS grid-template-rows и grid-template-columns свойства теперь можно анимировать во всех основных веб-браузерах! Что ж, CSS Grid уже давно технически поддерживает анимацию, так как она встроена прямо в спецификацию модуля компоновки CSS Grid Level 1.

Анимация для текста на CSS
Анимация для текста на CSS
В наше время без анимационных эффектов на сайте просто не обойтись. Это и слайдеры и скроллеры, различного рода реагирования элементов дизайна при наведении на них мышкой, это анимация при прокрутке страниц и различные выезжающие, выплывающие, выползающие и т.д. блоки контента. Дизайнеры используют свою фантазию на 100%, чтобы их дсайт выделился из общей массы и запомнился Пользователям...

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

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

Свойство clip-path
Свойство clip-path
Свойство clip-path в CSS позволяет указать конкретную область элемента для отображения, а остальная часть скрыта (или “обрезана”)...

QRcode

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

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

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