Красивый цветной текст в CSS: как это сделать
easy

Красивый цветной текст в CSS: как это сделать

Можно раскрасить хоть по диагонали

Допустим, вы фронтенд и вам дали задание раскрасить текст на сайте в разные цвета. Но что, если покраска не должна быть связана со словами? Например, если нужно покрасить текст по диагонали или сделать так, чтобы через буквы просвечивалась картинка? Оказывается, это тоже можно сделать довольно просто. Сейчас за 10 минут разложим вот такую красоту:

Чтобы полностью врубиться в эту технику, читайте комментарии в коде. Всё станет понятно.

Как вообще задать или поменять цвет шрифта в HTML и CSS

Самый простой способ задать или поменять цвет шрифта — обернуть нужные фрагменты текста в теги <span></span> и задать стили этим тегам. Это можно сделать через встроенные стили:

<!DOCTYPE html>
<html>
<body>

<p>Это пример текста с <span style="color: blue;">синим</span> текстом.</p>

</body>
</html>

Вариант посложнее — использовать внутренние стили, определив класс в элементе <style> внутри <head>, а затем применив его к тегу <span>:

<!DOCTYPE html>
<html>
<head>
<style>
.blue-text {
  color: blue;
}
</style>
</head>
<body>

<p>Это пример текста с <span class="blue-text">синим</span> текстом.</p>

</body>
</html>

Но лучше всего использовать внешние стили, прописанные в отдельном CSS-файле:

.blue-text {
  color: blue;
}

А после этого подключить файл со стилями к HTML-документу и ссылаться на него:

<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body>

<p>Это пример текста с <span class="blue-text">синим</span> текстом.</p>

</body>
</html>

При этом цвет можно задать по его названию по названию, например blue, как в примере выше, а можно с помощью различных цветовых форматов:

  • color: #00BFFF — HEX,
  • color: rgb(0, 191, 255) — RGB,
  • color: hsl(195, 100%, 50%) — HSL.

Это база, а у нас задача немного другая, вернёмся к ней.

Готовим страницу

Вся магия у нас будет происходить в CSS-файле, так что всё, что нам нужно сделать, — это добавить на страницу блок с заголовком и подключить файл со стилями:

<!DOCTYPE html>
<html lang="ru" >
<head>
  <meta charset="UTF-8">
  <title>Разноцветный текст на CSS</title>
  
<link rel="stylesheet" href="style.css">

</head>
<body>
  <!-- блок, в котором происходит магия цвета -->
  <div class="colored">
    <!-- обычный заголовок -->
    <h1>Привет, это журнал «Код»</h1>
  </div>
</body>
</html>

Настраиваем стили

Чтобы можно было быстро менять и подбирать цвета для раскрашивания, сделаем их переменными в CSS:

/* задаём глобальные переменные для цветов, в которые будем окрашивать текст */
:root {
  --color-1: #186cb8;
  --color-2: #2a9a9f;
  --color-3: #f1b211;
  --color-4: #e83611;
  --color-5: #f9002f;
}

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

/* настройки блока с текстом */
.colored {
  /* фон */
  background: #000;
  /* межстрочное расстояние */
  line-height: 1;
  /* подключаем сетку */
  display: grid;
  /* ставим содержимое в центр */
  place-items: center;
}

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

h1 {
  /* настраиваем внешний вид шрифта */
  font-family: sans-serif;
  font-size: 15vw;
  font-weight: 900;

  /* подстраиваем ширину заголовка под самое длинное слово*/
  width: -webkit-min-content;
  width: -moz-min-content;
  width: min-content;

  /* делаем автоматические отступы */
  margin: auto;
  /* переводим все буквы в заглавные */
  text-transform: uppercase;
}

Последнее, что осталось сделать, — наложить цвета поверх текста. Сделаем это так:

  1. Используем линейный градиент и повернём его для красоты по диагонали.
  2. Градиент — это переход от одного цвета к другому.
  3. Чтобы были цветные полосы, сделаем не плавный градиент, а полосками.
  4. Ширина каждой полоски будет 19%, а один процент оставим на зазор между ними.
  5. Чтобы полоски градиента были видны только на тексте, обрежем этот градиент по контуру букв.
  6. А чтобы буквы стали цветными, установим им прозрачный цвет — через него станет виден наш градиент.

Добавим это к стилям заголовка h1:

/* делаем цветные полосы по тексту */
background: linear-gradient(219deg, 
  var(--color-1) 19%, 
  transparent 19%,transparent 20%, 
  var(--color-2) 20%, var(--color-2)  39%,
  transparent 39%,transparent 40%, 
  var(--color-3) 40%,var(--color-3) 59% ,
  transparent 59%,transparent 60%, 
  var(--color-4) 60%, var(--color-4) 79%,
  transparent 79%, transparent 80%, 
  var(--color-5) 80%);
/* обрезаем фон по контуру букв */
background-clip: text;
-webkit-background-clip: text;

/* делаем заголовок прозрачным, чтобы был виден цветной фон */
color: transparent;

Что дальше

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

Посмотреть на градиенты на странице проекта.

<!DOCTYPE html>
<html lang="ru" >
<head>
  <meta charset="UTF-8">
  <title>Разноцветный текст на CSS</title>
  
<link rel="stylesheet" href="style.css">

</head>
<body>
  <!-- блок, в котором происходит магия цвета -->
  <div class="colored">
    <!-- обычный заголовок -->
    <h1>Привет, это журнал «Код»</h1>
  </div>
</body>
</html>

/* задаём глобальные переменные для цветов, в которые будем окрашивать текст */
:root {
  --color-1: #186cb8;
  --color-2: #2a9a9f;
  --color-3: #f1b211;
  --color-4: #e83611;
  --color-5: #f9002f;
}

/* настройки блока с текстом */
.colored {
  /* фон */
  background: #000;
  /* межстрочное расстояние */
  line-height: 1;
  /* подключаем сетку */
  display: grid;
  /* ставим содержимое в центр */
  place-items: center;
}

h1 {
  /* настраиваем внешний вид шрифта */
  font-family: sans-serif;
  font-size: 15vw;
  font-weight: 900;

  /* подстраиваем ширину заголовка под самое длинное слово*/
  width: -webkit-min-content;
  width: -moz-min-content;
  width: min-content;

  /* делаем автоматические отступы */
  margin: auto;
  /* переводим все буквы в заглавные */
  text-transform: uppercase;

  /* делаем цветные полосы по тексту */
  background: linear-gradient(219deg, 
    var(--color-1) 19%, 
    transparent 19%,transparent 20%, 
    var(--color-2) 20%, var(--color-2)  39%,
    transparent 39%,transparent 40%, 
    var(--color-3) 40%,var(--color-3) 59% ,
    transparent 59%,transparent 60%, 
    var(--color-4) 60%, var(--color-4) 79%,
    transparent 79%, transparent 80%, 
    var(--color-5) 80%);
  /* обрезаем фон по контуру букв */
  background-clip: text;
  -webkit-background-clip: text;

  /* делаем заголовок прозрачным, чтобы был виден цветной фон */
  color: transparent;
}

Художник:

Даня Берковский

Корректор:

Ирина Михеева

Вёрстка:

Кирилл Климентьев

Соцсети:

Виталий Вебер

Получите ИТ-профессию
В «Яндекс Практикуме» можно стать разработчиком, тестировщиком, аналитиком и менеджером цифровых продуктов. Первая часть обучения всегда бесплатная, чтобы попробовать и найти то, что вам по душе. Дальше — программы трудоустройства.
Получите ИТ-профессию Получите ИТ-профессию Получите ИТ-профессию Получите ИТ-профессию
Вам может быть интересно
easy