Меню

Как правильно подключить шрифт к сайту

Как подключить и оптимизировать нестандартные шрифты

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

Сразу стоит отметить, что самый простой вариант — вообще не подключать сторонние шрифты и пользоваться стандартными, которые предустановлены в большинстве операционных систем. Это хорошо знакомые Arial, Times New Roman и так далее — эти шрифты называются веб-безопасными, достаточно просто указать название одного из таких шрифтов в коде, и всё будет работать.

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

Для начала стоит выбрать правильный формат шрифта. TTF и OTF — форматы, которые предоставляются с минимальным сжатием или совсем без него. Их стоит использовать только в том случае, если нужна поддержка очень старых браузеров. Во всех остальных ситуациях можно выбрать WOFF и WOFF2 — форматы, которые отличаются высокой степенью сжатия. WOFF2 — усовершенствованная версия предшественника, этот формат можно считать лучшим из существующих. Тем не менее, поддержка WOFF2 хотя и очень хорошая, но пока не абсолютная, поэтому в качестве подстраховки для не самых современных браузеров стоит использовать WOFF.

Подключение шрифтов с помощью Google Fonts

Есть простой и удобный способ подключить нестандартный шрифт — использовать Google Fonts. Это бесплатный сервис, с помощью которого можно подключать шрифты, но не хранить их на своём сервере. Чтобы им воспользоваться, необходимо выбрать шрифт и добавить одно или несколько нужных начертаний, а затем вставить в ссылку, которую сгенерирует Google Fonts во вкладке Embed.

Этого достаточно, чтобы шрифт подключился. Теперь его можно использовать в свойстве font-family без каких-либо дополнительных действий.

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

Плюсы этого способа — простота использования и всегда актуальные версии шрифтов, Google Fonts их часто обновляет. Но у него есть и минус — запросы к сторонним серверам могут негативно повлиять на скорость загрузки страницы. Если выбираете этот способ, стоит обратить внимание на оптимизацию.

Подключение шрифтов с помощью правила @font-face

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

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

Также с помощью функции local можно добавить возможность перед загрузкой шрифта с сервера проверить, установлен ли он на компьютере пользователя. Если да, запроса к серверу за шрифтом не будет — при рендеринге используется локальная версия. Но у этого способа есть минус — шрифт на компьютере пользователя может быть устаревшим, и тогда страница отобразится не совсем так, как было задумано.

Базовый вариант правила:

Для улучшения производительности правило @font-face лучше всего прописывать в самом начале CSS-файла. Так браузер сможет раньше начать обработку шрифта.

Оптимизация

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

FOIT, FOUT и FOFT

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

FOIT (Flash of Invisible Text) — с англ. «мелькание невидимого текста». При таком поведении, пока шрифт не загрузится, текст не отображается и появляется только после загрузки шрифта. Значительная проблема — во время загрузки нет доступа к текстовому контенту.

Читайте также:  Как подключить 33 на киевстаре после пополнения

FOUT (Flash of Unstyled Text) — с англ. «мелькание неоформленного текста». Во время загрузки используется шрифт, заданный по умолчанию (системный, например), а после загрузки страница перерисовывается с использованием загрузившегося шрифта. Эта перерисовка довольно заметна и может быть нежелательна.

FOFT (Flash of Faux Text) — с англ. «мелькание синтезированного текста». Это поведение можно наблюдать в промежутке, когда основное начертание уже загрузилось, а дополнительные (жирное, курсивное и так далее) — нет. Браузер имитирует нужное начертание до загрузки настоящей версии. В этом случае страница может перерисовываться несколько раз по мере загрузки начертаний.

Свойство font-display

У свойства есть несколько значений, которые определяют поведение текста во время загрузки шрифта:

Предзагрузка шрифтов

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

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

Для того, чтобы предзагрузка сработала, нужно поместить в ссылку на шрифт и задать атрибуту rel значение preload :

Уменьшение количества глифов шрифта

По умолчанию шрифт может содержать глифы (буквы, символы) разных языков и просто редко используемые. С помощью свойства unicode-range можно установить диапазон нужных символов в системе Unicode, тогда браузер будет подгружать сабсет (подмножество) шрифта только в тот момент, когда на странице появится символ из этого диапазона. Предварительно нужно подготовить файлы шрифтов, разбив их на группы.

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

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

Google Fonts по умолчанию использует сабсеты. Это можно увидеть, открыв CSS-файл, который подключается в при использовании сервиса. Для каждого языка есть отдельный сабсет. Пример для латиницы и кириллицы:

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

Полезности

Подключение шрифтов — часть вёрстки

А научиться вёрстке проще, чем кажется. Скидка 1000₽ по промокоду SKUCHNO.

Источник

Как правильно подключать шрифты для сайта

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

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

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

Конвертация шрифтов

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

Так, одни понимает «woff», другой «ttf», а третьему «eof» подавай. Поэтому, если заказчик серьезный, то он передает на верстку макет и прилагает все форматы шрифтов, но это бывает очень редко. И нам, верстальщикам, зачастую, приходится самим выкручиваться из ситуации.

В начале своей работы в интернете для меня это было существенной проблемой, и я искал все форматы одного и того же шрифта вручную, но потом наткнулся на сервисы, конвертирующие из одного формата, во все необходимые для Web(а). Например:

То есть, они позволяют загрузить один формат шрифта и на его основе сгенерировать дополнительные.

Читайте также:  Как подключить компьютерные колонки к мопеду

Я, обычно, пользуюсь первым, поэтому и пример покажу на основе него. У меня есть бесплатный шрифт lazer84 [RUS by Daymarius]. Предположим, что я хочу использовать его на сайте, но у меня он есть только в формате ttf.

Первым делом, давайте назовем его осмысленно, ведь после скачивания он назывался «12236». Я переименую его в lazer, так будет удобнее с ним работать.

Теперь, давайте перейдем на сайт «onlinefontconverter» и выбираем необходимые форматы.

Затем жмем «select font(s)» и выбираем шрифт, которые хотим сконвертировать в указанные форматы. После загрузки жмем «Done», затем «Save your font» и «Download attachment».

Начнется скачивание архива.

Иногда, может возникнуть ошибка. В таком случае просто повторите процедуру.

Распакуйте архив и переместите шрифты в свой проект. Обычно, это папка «fonts».

Как видите, не все форматы получили такое же имя, которое мы задали немного ранее. Давайте переименуем.

Теперь займемся подключением к сайту. Откройте CSS-файл, который подключен к проекту и в самом начале подключите шрифты следующим образом.

Для более удобного копирования, вот код:

В «font-family» придумали удобное для подключения имя. В моем случае я так и оставил «lazer», теперь в любом месте, где понадобится использование этого шрифта, нужно просто указать его имя.

Если по какой-то причине шрифт не применился, то в первую очередь проверьте пути подключения. В 99% случаев проблема именно в этом.

4 комментария

Вот тут или у меня руки кривые, или 48 из 7-ми. Пишу все, как в примере:

просматриваю (использую OpenServer-платформу) — показывается в стандартных шрифтах

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

Да. и еще, сделайте, пожалуйста, уведомления на e-mail о Ваших ответах на комментарии к Вашим статьям. Это было бы удобно. Спасибо!

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

Источник

Подключение шрифтов из папки. CSS свойство font-face.

Есть разные способы подключения нестандартных шрифтов к сайту. Скриптом, с помощью сервиса Google fonts или из локальной папки сайта. Для реализации последнего из способов используют CSS-правило @font-face.

Одинаковые шрифты подключаются с одним именем, различающуюся жирность и стиль пишут в font-weight и font-style.

Для современных браузеров нужны форматы woff2 и woff. Вначале указывается путь к файлу woff2, затем к woff. Таким образом, если браузер умеет работать с более современным форматом шрифтов, то он применит его. Если нет, то возьмет формат woff.

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

Обязательно указывайте запасной веб-безопасный шрифт и семейство.

Свойство unicode-range

CSS свойство unicode-range задает определенный диапазон символов для шрифта, определенного в @font-face и доступного для использования на странице. Если на странице нет символов из указанного диапазона, то шрифт не загружается. Если же есть хоть один символ, то загрузится весь шрифт.

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

Обратите внимание, что unicode-range не разбивает сам шрифтовой файл, он только показывает нужно ли загружать этот файл, есть ли соответствующие ему символы.

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

Для подключения кириллицы:

Как это работает? Браузер анализирует ваш DOM и понимает какие символы используются на сайте и, если есть совпадение, то шрифт закачивается. В данном примере, если на сайте есть кириллица, то lato-light.cyrillic.woff2 будет загружен и отрисуется, а шрифт lato-light.latin.woff2 даже не закачается.

Или другой пример: вот таким способом можно применить другой шрифт только к цифровым символам:

Примечание: не работает с шрифтами подключенными через Google fonts, необходимо локальное подключение.

0020 — 007F Basic Latin 2580 — 259F Block Elements 00A0 — 00FF Latin-1 Supplement 25A0 — 25FF Geometric Shapes 0100 — 017F Latin Extended-A 2600 — 26FF Miscellaneous Symbols 0180 — 024F Latin Extended-B 2700 — 27BF Dingbats 0250 — 02AF IPA Extensions 27C0 — 27EF Miscellaneous Mathematical Symbols-A 02B0 — 02FF Spacing Modifier Letters 27F0 — 27FF Supplemental Arrows-A 0300 — 036F Combining Diacritical Marks 2800 — 28FF Braille Patterns 0370 — 03FF Greek and Coptic 2900 — 297F Supplemental Arrows-B 0400 — 04FF Cyrillic 2980 — 29FF Miscellaneous Mathematical Symbols-B 0500 — 052F Cyrillic Supplementary 2A00 — 2AFF Supplemental Mathematical Operators 0530 — 058F Armenian 2B00 — 2BFF Miscellaneous Symbols and Arrows 0590 — 05FF Hebrew 2E80 — 2EFF CJK Radicals Supplement 0600 — 06FF Arabic 2F00 — 2FDF Kangxi Radicals 0700 — 074F Syriac 2FF0 — 2FFF Ideographic Description Characters 0780 — 07BF Thaana 3000 — 303F CJK Symbols and Punctuation 0900 — 097F Devanagari 3040 — 309F Hiragana 0980 — 09FF Bengali 30A0 — 30FF Katakana 0A00 — 0A7F Gurmukhi 3100 — 312F Bopomofo 0A80 — 0AFF Gujarati 3130 — 318F Hangul Compatibility Jamo 0B00 — 0B7F Oriya 3190 — 319F Kanbun 0B80 — 0BFF Tamil 31A0 — 31BF Bopomofo Extended 0C00 — 0C7F Telugu 31F0 — 31FF Katakana Phonetic Extensions 0C80 — 0CFF Kannada 3200 — 32FF Enclosed CJK Letters and Months 0D00 — 0D7F Malayalam 3300 — 33FF CJK Compatibility 0D80 — 0DFF Sinhala 3400 — 4DBF CJK Unified Ideographs Extension A 0E00 — 0E7F Thai 4DC0 — 4DFF Yijing Hexagram Symbols 0E80 — 0EFF Lao 4E00 — 9FFF CJK Unified Ideographs 0F00 — 0FFF Tibetan A000 — A48F Yi Syllables 1000 — 109F Myanmar A490 — A4CF Yi Radicals 10A0 — 10FF Georgian AC00 — D7AF Hangul Syllables 1100 — 11FF Hangul Jamo D800 — DB7F High Surrogates 1200 — 137F Ethiopic DB80 — DBFF High Private Use Surrogates 13A0 — 13FF Cherokee DC00 — DFFF Low Surrogates 1400 — 167F Unified Canadian Aboriginal Syllabics E000 — F8FF Private Use Area 1680 — 169F Ogham F900 — FAFF CJK Compatibility Ideographs 16A0 — 16FF Runic FB00 — FB4F Alphabetic Presentation Forms 1700 — 171F Tagalog FB50 — FDFF Arabic Presentation Forms-A 1720 — 173F Hanunoo FE00 — FE0F Variation Selectors 1740 — 175F Buhid FE20 — FE2F Combining Half Marks 1760 — 177F Tagbanwa FE30 — FE4F CJK Compatibility Forms 1780 — 17FF Khmer FE50 — FE6F Small Form Variants 1800 — 18AF Mongolian FE70 — FEFF Arabic Presentation Forms-B 1900 — 194F Limbu FF00 — FFEF Halfwidth and Fullwidth Forms 1950 — 197F Tai Le FFF0 — FFFF Specials 19E0 — 19FF Khmer Symbols 10000 — 1007F Linear B Syllabary 1D00 — 1D7F Phonetic Extensions 10080 — 100FF Linear B Ideograms 1E00 — 1EFF Latin Extended Additional 10100 — 1013F Aegean Numbers 1F00 — 1FFF Greek Extended 10300 — 1032F Old Italic 2000 — 206F General Punctuation 10330 — 1034F Gothic 2070 — 209F Superscripts and Subscripts 10380 — 1039F Ugaritic 20A0 — 20CF Currency Symbols 10400 — 1044F Deseret 20D0 — 20FF Combining Diacritical Marks for Symbols 10450 — 1047F Shavian 2100 — 214F Letterlike Symbols 10480 — 104AF Osmanya 2150 — 218F Number Forms 10800 — 1083F Cypriot Syllabary 2190 — 21FF Arrows 1D000 — 1D0FF Byzantine Musical Symbols 2200 — 22FF Mathematical Operators 1D100 — 1D1FF Musical Symbols 2300 — 23FF Miscellaneous Technical 1D300 — 1D35F Tai Xuan Jing Symbols 2400 — 243F Control Pictures 1D400 — 1D7FF Mathematical Alphanumeric Symbols 2440 — 245F Optical Character Recognition 20000 — 2A6DF CJK Unified Ideographs Extension B 2460 — 24FF Enclosed Alphanumerics 2F800 — 2FA1F CJK Compatibility Ideographs Supplement 2500 — 257F Box Drawing E0000 — E007F Tags

Читайте также:  Как подключить sony playstation 3 super slim 500gb к телевизору

Источник