Как в css подключить другой css
Перейти к содержимому

Как в css подключить другой css

  • автор:

Как импортировать css в css

Для импорта одного css файла внутрь другого используется конструкция @import . Достаточно указать внутри url() путь к нужному файлу и его содержимое подставится в то место, где был указан импорт.

@import url("custom.css"); @import url("mega-style.css"); 

@import

Правило @import позволяет импортировать содержимое CSS-файла в текущую стилевую таблицу. @import не разрешается вставлять после любых объявлений кроме @charset или другого @import .

Синтаксис

@import url("имя файла") [типы носителей]; @import "имя файла" [типы носителей];

В качестве типа носителя выступают различные устройства, например, принтер, КПК, монитор и др. В табл. 1 перечислены некоторые из них.

Табл. 1. Типы носителей и их описание

Тип Описание
all Все типы. Это значение используется по умолчанию.
aural Речевые синтезаторы, а также программы для воспроизведения текста вслух. Сюда, например, можно отнести речевые браузеры.
braille Устройства, основанные на системе Брайля, которые предназначены для слепых людей.
handheld Наладонные компьютеры и аналогичные им аппараты.
print Печатающие устройства вроде принтера.
projection Проектор.
screen Экран монитора.
tv Телевизор.

Использование типов носителей совместно с импортом файла дает возможность указывать стиль только для определенных устройств.

Значения

В качестве значения используется путь к стилевому файлу, который указывается внутри необязательной конструкции url() . Путь к файлу при этом можно писать как в кавычках (двойных или одинарных), так и без них.

HTML5 CSS2.1 IE Cr Op Sa Fx

    Импорт стиля   

.

Браузеры

Браузер Internet Explorer до версии 7.0 включительно не поддерживает типы носителей при импорте стилевого файла. Более того, при добавлении типа носителя стилевой файл вообще не загружается.

@import

При помощи директивы @import можно импортировать один файл со стилями в другой файл со стилями.

Пример

Скопировать ссылку «Пример» Скопировано

Предположим, в проекте для удобства стили разделены на несколько файлов:

  1. fonts.css — файл с подключением шрифтов и стилями.
  2. buttons.css — файл со стилями для кнопок.
  3. main.css — основной файл стилей с остальным CSS-кодом.

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

 @import "fonts.css";@import "buttons.css"; /* Остальной CSS-код */ @import "fonts.css"; @import "buttons.css"; /* Остальной CSS-код */      

Как пишется

Скопировать ссылку «Как пишется» Скопировано

Начнём с важного: все директивы импорта должны быть в самом верху CSS-файла, до всего остального кода. Иначе не сработает.

Равнозначные варианты импорта:

 @import "file.css";@import url("file.css"); @import "file.css"; @import url("file.css");      

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

Можно указать, для каких типов устройств должны применяться стили из импортируемого файла:

 @import "print-styles.css" print;@import "screen-styles.css" screen; @import "print-styles.css" print; @import "screen-styles.css" screen;      

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

Допустимо указывать несколько медиавыражений после пути:

 @import "file.css" (min-width: 481px) and (max-width: 768px);@import "file.css" screen and (orientation: landscape); @import "file.css" (min-width: 481px) and (max-width: 768px); @import "file.css" screen and (orientation: landscape);      

Можно проверить, поддерживается ли какое-то конкретное правило или выражение в браузере пользователя, и загрузить для него конкретные стили. Для этого используется правило supports :

 @import "file.css" supports(not (display: flex)); /* Остальной CSS-код */ @import "file.css" supports(not (display: flex)); /* Остальной CSS-код */      

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

Как понять

Скопировать ссылку «Как понять» Скопировано

Во время загрузки страницы браузер пройдёт по всем указанным в импортах путям и загрузит таблицы стилей. Затем прочитает правила ниже импортов и отрисует страницу на основании комбинации всего CSS.

Подсказки

Скопировать ссылку «Подсказки» Скопировано

�� Желательно не злоупотреблять импортами. Потенциально это может замедлить загрузку страницы.

�� Все импорты всегда должны быть в начале CSS-файла.

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

На практике

Скопировать ссылку «На практике» Скопировано

Алёна Батицкая советует

Скопировать ссылку «Алёна Батицкая советует» Скопировано

�� Кроме импорта файлов внутри проекта можно встретить использование этой директивы для импорта шрифтов с сайта Google Fonts. Это один из предложенных на их сайте вариантов подключения.

 @import url("https://fonts.googleapis.com/css2?family=Andika+New+Basic&display=swap"); @import url("https://fonts.googleapis.com/css2?family=Andika+New+Basic&display=swap");      

После этого в коде ниже можно использовать подключённый шрифт. Минимум усилий — максимум результата.

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

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

�� Если проект большой, то удобно разделять стили на разные файлы. Отдельно стили для разметки, отдельно для типографики, отдельно для форм и кнопок. В этом случае в основном файле стилей — назовём его style.css — будут только импорты. Так удобнее содержать код в чистоте. И всегда точно знаешь, в какой файл залезть, чтобы что-нибудь поправить.

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

CSS: Подключение файла через @IMPORT или LINK

Для подключения файла стилей CSS можно воспользоваться несколькими способами. Кто-то предпочитает использовать вставку через LINK а кто-то любит @IMPORT . Как же понять — какой способ использовать предпочтительнее всего? Ответ на этот вопрос нам даст Google (думаю, ему можно доверять в этом плане). Корпорация добра дает следующие характеристики описанных выше методов.

Итак, для подключения файла стилей у нас есть 2 способа:

Или же внутри самого файла стилей через директиву @import

@import url('style.css'); 

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

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

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

Если же не получится, то загружайте их параллельно:

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *