С момента появления веб-шрифтов в 2009 году веб-дизайнеры получили доступ к богатому набору типографских палитр. Эти шрифты в основном применялись через правило CS @fontface, что позволяло дизайнерам отказаться от использования системных (веб-безопасных) шрифтов.

Крупные разработчики шрифтов предлагали (и предлагают) разнообразные форматы файлов шрифтов, в первую очередь Google Fonts.
В то время использование веб-шрифтов означало работу с отдельными файлами для каждого начертания и стиля. Например, такие имена файлов ясно показывали, как шрифт будет отображаться при использовании:
Roboto-Italic.woff2
Lato-BoldItalic.woff2
OpenSans-SemiBold.ttf
WorkSans-ExtraBold.ttf.
Каждый вариант приходилось загружать как отдельный файл. Это увеличивало размер страницы, требовало больше HTTP-запросов и усложняло выбор и применение шрифтов в дизайне.
Рост популярности вариативных шрифтов
В 2016 году произошел крупный прорыв в цифровой типографике: появились вариативные шрифты. Разработанные совместно Google, Apple, Adobe и Microsoft, они быстро стали популярными.
Отличительной особенностью вариативного шрифта является то, что он может содержать любой из следующих элементов, каждый из которых называется осью:
| Ось | CSS-свойство |
| толщина | font-weight |
| стиль | font-style: italic |
| наклонный | font-style: oblique |
| растягивающийся | font-stretch |
| Оптический размер оси (opsz) | font-variations-setting |
Наиболее распространённым форматом файла является .woff2 (Web Open Font Format) — формат с высокой степенью сжатия, получивший рекомендацию W3C в 2018 году. Хотя такие форматы, как .ttf и .otf можно использовать в качестве вариативных шрифтов, наиболее эффективным является формат .woff2. Все современные браузеры поддерживают вариативные шрифты.
Для ясности мы проводим различие между «веб-шрифтами» и «вариативными шрифтами». Однако на практике вариативные шрифты часто объединяют с веб-шрифтами.
Зачем использовать переменные шрифты?
Есть три веские причины использовать вариативные шрифты в своих проектах:
- Повышенная производительность: вместо вызова нескольких отдельных файлов шрифтов (обычный, полужирный, курсив и т. д.) один файл переменного шрифта может охватывать все шрифты. Это означает меньше HTTP-запросов и более быструю загрузку.
- Гибкость дизайна: переменные шрифты обеспечивают точный контроль. Например, вместо того, чтобы ограничиваться значениями
font-weight: 500или600, можно задать пользовательское значение, например532. - Адаптивная типографика: поскольку вариативные шрифты легко адаптируются, вы можете создавать типографику, которая будет реагировать на все устройства. Хороший пример:
font-weight: clamp()масштабирование веса между областями просмотра без резких «скачков», характерных для статических файлов шрифтов.
Как WordPress использует переменные шрифты
С выпуском WordPress 6.1 в ноябре 2022 года в систему была добавлена поддержка переменных шрифтов theme.json. Впервые это было продемонстрировано в Twenty Twenty-Three.
Настройка темы с помощью переменных шрифтов
При работе с дочерней темой TT5 мы начинаем с добавления в очередь стилей родительской и дочерней темы.
Чтобы гарантировать единообразное отображение наших пользовательских шрифтов как в редакторе, так и во внешнем интерфейсе, также добавляем в очередь fonts.css файл, содержащий необходимые @font-face объявления.
<?php
// enqueue parent and child styles
add_action('wp_enqueue_scripts', function() {
wp_enqueue_style(
'parent-style',
get_template_directory_uri() . '/style.css'
);
wp_enqueue_style(
'child-style',
get_stylesheet_uri(),
array('parent-style'),
wp_get_theme()->get('Version')
);
// enqueue custom fonts
wp_enqueue_style(
'child-fonts',
get_stylesheet_directory_uri() . '/fonts.css',
array(),
wp_get_theme()->get('Version')
);
});Как всегда, способ добавления скриптов в очередь зависит от самой темы. Единого стандартного метода не существует.Чтобы убедиться, что мы правильно настроили дочернюю тему, запускаем этот тест styles.css:
body { background: #0000ff; }Добавление шрифтов с помощью theme.json
В TT5 по умолчанию уже включены два вариативных шрифта: Manrope и Fira Code . В этом примере добавим Vollkorn и сделаем его шрифтом заголовков по умолчанию с толщиной 600.
Вот соответствующая часть theme.json:
{
"$schema": "https://schemas.wp.org/wp/6.7/theme.json",
"version": 3,
"settings": {
"appearanceTools": true,
"typography": {
"fontFamilies": [
{
"name": "Manrope",
"slug": "manrope",
"fontFamily": "Manrope, sans-serif",
"fontFace": [
{
"fontFamily": "Manrope",
"src": ["file:../twentytwentyfive/assets/fonts/manrope/Manrope-VariableFont_wght.woff2"],
"fontWeight": "200 800",
"fontStyle": "normal"
}
]
},
{
"name": "Fira Code",
"slug": "fira-code",
"fontFamily": "\"Fira Code\", monospace",
"fontFace": [
{
"fontFamily": "\"Fira Code\"",
"src": ["file:../twentytwentyfive/assets/fonts/fira-code/FiraCode-VariableFont_wght.woff2"],
"fontWeight": "300 700",
"fontStyle": "normal"
}
]
},
{
"name": "Vollkorn",
"slug": "vollkorn",
"fontFamily": "Vollkorn, serif",
"fontFace": [
{
"fontFamily": "Vollkorn",
"src": ["file:../twentytwentyfive/assets/fonts/vollkorn/Vollkorn-VariableFont_wght.woff2"],
"fontWeight": "400 900",
"fontStyle": "normal"
},
{
"fontFamily": "Vollkorn",
"src": ["file:../twentytwentyfive/assets/fonts/vollkorn/Vollkorn-Italic-VariableFont_wght.woff2"],
"fontWeight": "400 900",
"fontStyle": "italic"
}
]
}
],
"customFontSize": true,
"fluid": true
}
},
"styles": {
"typography": {
"fontFamily": "var:preset|font-family|manrope"
},
"elements": {
"heading": {
"typography": {
"fontFamily": "var:preset|font-family|vollkorn",
"fontWeight": "600"
}
}
}
}
} Результатом стало появление шрифта Vollkorn на всем сайте.

Шрифт Vollkorn теперь доступен в библиотеке шрифтов WordPress.
Следует отметить несколько моментов:
- Возможно, вы захотите скопировать файлы Manrope и Fira Code своей дочерней теме в случае, если TT5 обновится и укажет новые пути к файлам.
- Может показаться, что код для этих шрифтов избыточен, поскольку они уже зарегистрированы в родительской теме. Однако важно объявить их в дочерней теме. Это гарантирует их корректное отображение в интерфейсе библиотеки шрифтов и их доступность даже при обновлении родительской темы с новыми путями к файлам или внесении изменений.
- Мы ссылаемся на два разных файла Vollkorn.
Обеспечение правильной загрузки шрифтов
Иногда шрифты не отображаются корректно на странице, пока вы не объявите их в CSS. Вот типичный пример styles.css:
/*
Theme Name: TT5 Child
Template: twentytwentyfive
Version: 1.0
*/
/* Ensure fonts are loaded and applied */
body {
font-family: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
Oxygen-Sans, Ubuntu, Cantarell, sans-serif;
}
code,
pre {
font-family: 'Fira Code', 'Courier New', monospace;
}
h1,
h2,
h3,
h4,
h5,
h6 {
font-family: 'Vollkorn', 'Times New Roman', serif;
}А в fonts.css мы объявляем файлы шрифтов с помощью @font-face. Это гарантирует, что браузер знает, какие шрифты загружать и применять. Если вы хотите действительно предварительно загрузить критически важные шрифты (например, основной шрифт заголовка), то можете добавить <link rel="preload"> к сайту <head>dir="auto"> через хуки WordPress. В большинстве случаев @font-face правило с font-display: swap обеспечивает хороший баланс между производительностью и пользовательским опытом.
/* Preload critical fonts for better performance */
@font-face {
font-family: 'Manrope';
src: url('../twentytwentyfive/assets/fonts/manrope/Manrope-VariableFont_wght.woff2')
format('woff2');
font-weight: 100 900;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Fira Code';
src: url('../twentytwentyfive/assets/fonts/fira-code/FiraCode-VariableFont_wght.woff2')
format('woff2');
font-weight: 100 900;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Vollkorn';
src: url('../twentytwentyfive/assets/fonts/vollkorn/Vollkorn-VariableFont_wght.woff2')
format('woff2');
font-weight: 100 900;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Vollkorn';
src: url('../twentytwentyfive/assets/fonts/vollkorn/Vollkorn-Italic-VariableFont_wght.woff2')
format('woff2');
font-weight: 100 900;
font-style: italic;
font-display: swap;
} В результате получается страница, на которой заголовки по умолчанию имеют шрифт Vollkorn с весом 600.

При желании можно включить @font-face-правила в styles.css. Это также избавит от необходимости добавлять fonts.css файл в очередь.
Упрощаем для пользователей выбор начертания шрифта
Одно из главных преимуществ переменных шрифтов заключается в том, что их насыщенность не ограничена фиксированными значениями, такими как 400 или 600. Вы можете использовать любое значение от 100 до 900. Проблема в том, что WordPress не предоставляет встроенного пользовательского интерфейса для выбора этих значений насыщенности.
Чтобы решить эту проблему, мы создали минималистичный плагин под названием «Параметры начертания шрифта». Он добавляет страницу настроек в раздел «Внешний вид» > «Начертание шрифта», где можно задать собственные значения начертания для основного текста, заголовков и блоков кода.
Вот сокращенный взгляд на основную логику:
<?php
/**
* Plugin Name: Font Weight Options
*/
class Font_Weight_Options {
public function __construct() {
add_action( 'admin_menu', array( $this, 'add_admin_menu' ) );
add_action( 'wp_head', array( $this, 'apply_font_weights_frontend' ) );
}
public function add_admin_menu() {
add_theme_page(
__( 'Font Weight Settings', 'font-weight-options' ),
__( 'Font Weight', 'font-weight-options' ),
'manage_options',
'font-weight-settings',
array( $this, 'render_admin_page' )
);
}
public function apply_font_weights_frontend() {
$weights = get_option( 'fwo_font_weights', array(
'body' => 400,
'headings' => 600,
'code' => 400,
) );
echo "<img src="" data-wp-preserve="%3Cstyle%3E%0A%20%20%20%20%20%20%20%20%20%20%20%20body%20%7B%20font-weight%3A%20%7B%24weights%5B'body'%5D%7D%20!important%3B%20%7D%0A%20%20%20%20%20%20%20%20%20%20%20%20h1%2C%20h2%2C%20h3%2C%20h4%2C%20h5%2C%20h6%20%7B%20font-weight%3A%20%7B%24weights%5B'headings'%5D%7D%20!important%3B%20%7D%0A%20%20%20%20%20%20%20%20%20%20%20%20code%2C%20pre%20%7B%20font-weight%3A%20%7B%24weights%5B'code'%5D%7D%20!important%3B%20%7D%0A%20%20%20%20%20%20%20%20%3C%2Fstyle%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<style>" title="<style>" />";
}
}
new Font_Weight_Options();Фрагмент выше демонстрирует основную логику. Мы опубликовали полный исходный код на GitHub Gist, если вы хотите увидеть плагин целиком, включая форму настроек и валидацию.
Полная версия добавляет:
- Значения по умолчанию при активации плагина.
- Простая форма настроек администратора с числовыми полями (100–900).
- Проверка для поддержания значений в пределах диапазона.
- Вывод весов как в редакторе блоков, так и в интерфейсе.
В результате появилась новая страница в панели администратора WP, которая позволяет пользователям устанавливать значения насыщенности для трёх шрифтов. Мы выбрали три «нестандартных» значения.

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

Страница в админке WordPress, отображающая три шрифта с назначенной им шириной.
Более простой и удобный способ добавить один переменный шрифт
Но что делать, если вы предпочитаете что-то другое, а не шрифт Google? Существует множество способов получить должным образом лицензированные шрифты с открытым исходным кодом для ваших проектов. Мы обратились к GitHub, чтобы получить SourceSans3VF-Upright — шрифт Adobe.
Наша цель — использовать его как дополнительный шрифт, который будет корректно отображаться в редакторе и на внешнем интерфейсе.
Файл шрифта находится в /assets/fonts папке нашей дочерней темы. Там мы создали functions.php.
<?php
/**
* Enqueue parent and child theme styles.
*/
function twentytwentyfive_kinstachild_enqueue_styles() {
// Parent theme style.
wp_enqueue_style(
'twentytwentyfive-style',
get_parent_theme_file_uri( 'style.css' ),
array(),
wp_get_theme()-&amp;amp;gt;get( 'Version' )
);
// Child theme style.
wp_enqueue_style(
'twentytwentyfive-child-style',
get_stylesheet_uri(),
array( 'twentytwentyfive-style' ),
wp_get_theme()-&amp;amp;gt;get( 'Version' )
);
}
add_action( 'wp_enqueue_scripts', 'twentytwentyfive_kinstachild_enqueue_styles' );
/**
* Enqueue child theme styles in the editor.
*/
add_action( 'after_setup_theme', function() {
add_editor_style( 'style.css' );
} );Информация
Обратите внимание, что в этой более простой настройке мы не добавляем пользовательские шрифты в очередь вручную. Это связано с тем, что переменные шрифты, определенные в
theme.json, автоматически обрабатываются WordPress, если они правильно объявлены. Это одно из преимуществ использования блочной системы тем.
Как и в предыдущем примере, theme.json файл должен ссылаться на коды Manrope и Fira из родительского файла. Отсутствие этих ссылок приведет к их удалению из темы.
{
"$schema": "https://schemas.wp.org/wp/6.7/theme.json",
"version": 3,
"settings": {
"typography": {
"fontFamilies": [
{
"name": "Manrope",
"slug": "manrope",
"fontFamily": "Manrope, sans-serif",
"fontFace": [
{
"src": [
"file:../twentytwentyfive/assets/fonts/manrope/Manrope-VariableFont_wght.woff2"
],
"fontWeight": "100 900",
"fontStyle": "normal",
"fontFamily": "Manrope"
}
]
},
{
"name": "Fira Code",
"slug": "fira-code",
"fontFamily": "\"Fira Code\", monospace",
"fontFace": [
{
"src": [
"file:../twentytwentyfive/assets/fonts/fira-code/FiraCode-VariableFont_wght.woff2"
],
"fontWeight": "100 900",
"fontStyle": "normal",
"fontFamily": "\"Fira Code\""
}
]
},
{
"name": "Source Sans 3",
"slug": "source-sans-3",
"fontFamily": "\"Source Sans 3\", sans-serif",
"fontFace": [
{
"src": [
"file:./assets/fonts/SourceSans3VF-Upright.woff2"
],
"fontWeight": "100 900",
"fontStyle": "normal",
"fontFamily": "Source Sans 3"
}
]
}
]
}
}
}Помните, что по-прежнему нужен базовый styles.css файл, включающий необходимые метаданные, сообщающие WordPress, что вы работаете с дочерней темой.
Независимо от того, выбираете ли вы полностью индивидуальную настройку или быструю интеграцию, вариативные шрифты в WordPress — это мощный способ улучшить типографику вашего сайта. Они повышают производительность, упрощают дизайн и предоставляют адаптивные и гибкие возможности дизайна, которые просто невозможно реализовать с помощью традиционных статических шрифтов.
Чтобы раскрыть весь их потенциал, может потребоваться создать специальный пользовательский интерфейс, который отображает переменные оси (например, вес, наклон или оптический размер) и предоставляет владельцам сайтов больше контроля.
Источник: kinsta.com





















Комментарии к записи: 0