Как подключить CSS к HTML – быстрые способы для начинающих
Есть 5 способов подключения CSS к HTML и 500 ошибок, которые возникнут, если неправильно подключить CSS – не рассчитать приоритеты или «задушить» нормальное распределение приоритетов инструкцией !important. Ниже мы расскажем про все варианты оформления сайта через подключение CSS, вкратце коснемся темы подключения шрифтов и расскажем, как избежать путаницы, если ваши таблицы стилей переопределяют друг друга.
Способы подключения CSS к HTML
Внутренние таблицы стилей
Внешние таблицы стилей
Импорт чужого CSS
Приоритеты стилей
Что почитать по теме
Подведем итоги
Способы подключения CSS к HTML
Сначала вкратце рассмотрим подключение и способы доступа к элементам всеми способами, ниже дадим более детальную информацию с примерами:
- Внутри HTML, атрибутом style. В этом случае стиль применяется конкретно к элементу, которому вы это задали.
- Внутри HTML, с помощью тегов style. Если прописываете стиль, например, для <p>, то всему HTML документу (всем тегам p в нем) будет присвоен этот стиль.
- Отдельным файлом, селектор тега. В общем-то, отличий от предыдущего варианта здесь не так и много – вы просто прописываете файлу index CSS-файл, из которого можно брать стили. Так можно быстро подключить шрифты для всей страницы через Google Fonts, подключить шрифты от Гугла через теги style будет намного сложнее.
- Отдельным файлом, селекторы классов и идентификаторов. Более полезный инструмент, позволяет иметь несколько вариантов оформления на различные случаи жизни. Если еще подключить JavaScript, то можно менять варианты подключения и оформления на лету.
- Подключение внешних файлов. Если где-то лежит внешняя таблица, никто не мешает вам подключить ее на свою страницу. Подключать внешние таблицы – не самый безопасный вариант, но ниже мы расскажем, как это поправить.
Внутренние таблицы стилей
Итак, способы подключения, относящиеся ко внутренним таблицам, разбиты на 2 части: внутри HTML и в отдельном CSS. Если хотите обойтись без внешних файлов вовсе – этого можно достичь с помощью использования атрибутов style. Style можно прописать как отдельному элементу, так и всему html-документу. Первый случай:
<p>Пример текста</p>
Здесь вы объявляете style внутри тега, после чего прописываете все необходимые параметры.
Для второго варианта нужно воспользоваться тегом head и прописать style внутри него:
<style> h2 { font-size: 140%; font-family: Arial, Helvetica, sans-serif; color: red; } </style>
В этом случае описанный стиль будет применяться по всем h2 на странице (если у вас их по каким-то причинам больше 1).
Из всех методов подключения эти два – самые плохие. Дело в том, что у них очень высокий приоритет, и они будут перекрывать все другие стили, если у последних не прописан !important. Если у вас простой одностраничник – это может не сильно сказаться на верстке, но для более-менее крупного сайта отлавливание багов верстки при наличии внутренних стилей – настоящий ад, поэтому за прописывание style внутри HTML-страницы бьют по рукам на любой работе.
Внешние таблицы стилей
Общепринятый способ хранения (и подключения) верстки – в отдельных файлах с форматом .css. В этом случае в начале файла вам нужно подключить внешнюю таблицу тегом link:
<link rel="stylesheet" href="mysite.css">
В href нужно указывать путь к файлу. Если таблица лежит в той же папке, что и html-файл, можете просто указать имя таблицы (файла). Если же стиль лежит в подпапке, вам нужно указать относительный путь, например:
href="css/style.css"
Теперь – о разных способах доступа к элементу в вынесенных каскадных таблицах. Есть 2 варианта. Первый – это задание стиля всем экземплярам определенного тега, например:
p { padding-right: 30px; }
Инструкция будет действовать на все теги p. Второй вариант – это доступ через классы и идентификаторы. В HTML-странице мы указываем какому-либо экземпляру класс и/или id, например:
<p>…</p> <p>…</p>
После чего меняем в css-файле отображение класса или идентификатора:
. colored { color: blue; }
или
#intro { font-size: 1.2em; }
По возможности пользуйтесь именно этими способами – они доставляют меньше всего проблем. При этом лучше пользоваться классами, чем id – код JavaScript часто работает с id, и может получиться так, что JS-скрипт изменит id элемента, к которому вы применяете стиль, и верстка поедет.
Импорт чужого CSS
Наконец, последний вариант – это импорт чужих таблиц стилей. Делается он так же, как и импорт ваших собственных таблиц, но вместо адреса у себя на хостинге вы должны указать полный URL-адрес, например:
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-gh3yIJqKdNHPEq0n4Mqa/HGKIhSkIHeL5AyhkYV8i59U5AR6csBvApHHNl/vI1Bx" crossorigin="anonymous">
Код выше подключает css-файл фреймворка Bootstrap. Таким же образом можно подключать стили Google Fonts:
<link rel="preconnect" href="https://fonts. googleapis.com"> <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> <link href="https://fonts.googleapis.com/css2?family=Roboto:ital,[email protected],100&display=swap" rel="stylesheet">
Опасность заключается в том, что автор может изменить свой css-файл, и тогда у вас тоже отразятся эти изменения. Если вы берете стиль у какой-то крупной компании или стиль фреймворка, то они не изменятся никогда, можете не переживать. Если же вы «подрезаете» стиль у другого сайта – лучше скопировать себе .css-файл этого сайта и подключить его уже со своего хостинга, этим вы застрахуете себя от незапланированных изменений.
Приоритеты стилей
Итак, а теперь нужно рассказать про конфликты приоритетов. Предположим ситуацию, что у вас одновременно для тега
- Стиль прописан внутри тега (inline-метод): 1000 условных единиц.
- Стиль прописан в <style> или в другом файле, обращение по id: 100 условных единиц.
- Стиль прописан в <style> или в другом файле, обращение по class: 10 условных единиц.
- Стиль прописан в <style> или в другом файле, обращение по названию тэга (p, h2 и так далее): 1 условная единица.
Если селектор содержит в себе несколько указаний (определенный класс + определенный тэг, например), то веса складываются, класс + тэг = 10 + 1 = 11. Если браузеру нужно выбрать между несколькими стилями, он выбирает тот, у которого больше вес. Если 2 и больше стиля имеют одинаковый вес – выбирает тот, который был описан последним, то есть если у вас подключены 2 таблицы:
<link href="ссылка на другой сайт" rel="stylesheet> <link href="ссылка на таблицу на вашем сайте" rel="stylesheet>
и в обеих есть определение нужного браузеру стиля – он выберет таблицу на вашем сайте. Если же в одной таблице стилей есть 2 конфликтующих описания – будет выбрано то, что ниже.
Перекроить приоритеты может только !important. Можете считать его как +10 000 к весу. Проблема !important заключается в том, что если у вас есть несколько стилей с !important, то у них будет вес, например, 10 001 и 10 010, то есть они будут создавать новую систему весов над уже имеющейся. Поэтому: 1) если вам нужен один
Что почитать по теме
- Google Fonts.
- Разъяснения по !important.
Подведем итоги
Тезисно:
- Подключить CSS к HTML можно внутри html, отдельным файлом у себя на хостинге, и отдельным файлом где-то в интернете.
- Не стоит прописывать стили CSS прямо внутри HTML – очень плохая практика, которая способна сломать верстку.
- Если вы берете css с какого-то другого сайта и боитесь, что владелец сайта может изменить свою таблицу стилей – лучше сделайте копию.
- У стилей есть веса, при конфликте стилей с одинаковыми весами используется тот, который прописан ниже по коду (потоку исполнения). Учитывайте это, когда подключаете несколько таблиц стилей.
Шрифты Google
Если вы не хотите использовать стандартные шрифты, вы можете использовать шрифты Google.
Google предоставляет более 1000 самых разнообразных шрифтов и все они полностью беcплатны.
Как использовать шрифты Google
Чтобы подключить шрифт Google, достаточно добавить ссылку подключения файла таблицы стилей в секции <head> и определить этот шрифт в своих стилях CSS.
В следующем примере мы подключаем и затем используем шрифт Google с именем «Sofia»:
<head> <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Sofia"> <style> body { font-family: "Sofia", sans-serif; } </style> </head>
Результат:
Sofia Font
Lorem ipsum dolor sit amet.
123456790
В следующем примере мы подключаем и затем используем шрифт Google с именем «Trirong»:
<head> <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Trirong"> <style> body { font-family: "Trirong", serif; } </style> </head>
Результат:
Trirong Font
Lorem ipsum dolor sit amet.
123456790
В следующем примере мы подключаем и затем используем шрифт Google с именем «Audiowide»:
<head> <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Audiowide"> <style> body { font-family: "Audiowide", sans-serif; } </style> </head>
Результат:
Audiowide Font
Lorem ipsum dolor sit amet.
123456790
Примечание: При определении шрифта в CSS всегда указывайте как минимум один резервный шрифт (чтобы избежать неожиданного поведения). Также, в конец списка следует добавлять стандартную группу шрифта (вроде serif или sans-serif).
Использование нескольких шрифтов Google
Чтобы загрузить сразу несколько шрифтов Google, просто разделите имена шрифтов вертикальной чертой ( |
).
В следующем примере подключается несколько шрифтов Google:
<head> <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Audiowide|Sofia|Trirong"> <style> h2.a {font-family: "Audiowide", sans-serif;} h2.b {font-family: "Sofia", sans-serif;} h2.c {font-family: "Trirong", serif;} </style> </head>
Внимание! Загрузка большого количества шрифтов Google может замедлить вашу веб-страницу. Будьте с этим осторожны!
Стилизация шрифтов Google
Конечно же вы можете стилизовать шрифты Google также как и стандартные шрифты!
В следующем примере тексту, написанному шрифтом «Sofia», добавляется тень:
<head> <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Sofia"> <style> body { font-family: "Sofia", sans-serif; font-size: 30px; text-shadow: 3px 3px 3px #ababab; } </style> </head>
Результат:
Sofia Font
Lorem ipsum dolor sit amet.
123456790
Подключение к шрифтам различных эффектов
Google позволяет вместе с шрифтами также подключить к ним различные визуальные эффекты.
Сначала в теге подключения шрифта нужно добавить строку effect=имяэффекта
, а затем в элемент, где будет использоваться этот эффект нужно добавить специальный класс. Этот класс всегда начинается с font-effect-
, к которому добавляется имяэффекта
.
В следующем примере добавляется эффект огня к шрифту «Sofia»:
<head> <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Sofia&effect=fire"> <style> body { font-family: "Sofia", sans-serif; font-size: 30px; } </style> </head> <body> <h2>Sofia on Fire</h2> </body>
Результат:
Sofia on Fire
Чтобы подключить к шрифтам Google сразу несколько эффектов, просто разделите их имена вертикальной чертой ( |
).
В следующем примере добавляется несколько эффектов к шрифту «Sofia»:
<head> <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Sofia&effect=neon|outline|emboss|shadow-multiple"> <style> body { font-family: "Sofia", sans-serif; font-size: 30px; } </style> </head> <body> <h2>Neon Effect</h2> <h2>Outline Effect</h2> <h2>Emboss Effect</h2> <h2>Multiple Shadow Effect</h2> </body>
Результат:
Neon Effect
Outline Effect
Emboss Effect
Multiple Shadow Effect
Встраивание веб-шрифтов в выходные данные HTML
Пользовательский подключаемый модуль может быть создан для создания выходных данных HTML, использующих пользовательские шрифты для улучшения типографики. функции, расширенные наборы символов или уникальный фирменный стиль.
Об этой задаче
Этот сценарий описывает процесс создания очень простого подключаемого модуля. ( com.example.html5-webfont
), который создает новый тип преобразования:
html5-веб-шрифт.
Преобразование html5-webfont включает пользовательский файл CSS и задает пять параметров для интегрируйте ссылки на шрифты и пользовательскую таблицу стилей в сгенерированный вывод HTML5. Эти настройки параметров делают следующие изменения:
Укажите файл, который ссылается на шрифт из заголовка документа с помощью args.hdf.
Укажите подпапку css подключаемого модуля в качестве исходного каталога для пользовательского CSS с args.cssroot.
Укажите имя пользовательского файла CSS с помощью args.css.
Значение этого параметра указывает DITA-OT использовать файл custom.css, предоставленный плагин.
Убедитесь, что файл CSS скопирован в выходной каталог, задав для args. copycss значение да.
Задайте путь назначения для файлов CSS в выходной папке с помощью args.csspath.
Файлы CSS по умолчанию копируются в корневую папку выходной папки. Установка этого параметра помещает CSS файлы в специальной подпапке css.
Все пять параметров задаются в сценарии Ant (build_html5-webfont.xml).
Процедура
- В каталоге плагинов создайте каталог с именем com.example.html5-веб-шрифт.
- В новом каталоге com.example.html5-webfont создайте файл конфигурации плагина.
(plugin.xml), который объявляет новое преобразование html5-webfont и
его зависимости.
Рисунок 1. Пример файла plugin.xml
<плагин>
dita.html5"/> Примечание. Этот подключаемый модуль расширяет преобразование HTML5 по умолчанию, поэтому
- В каталоге com.example.html5-webfont создайте подкаталог с именем включать.
- В новом подкаталоге include создайте файл с именем
webfont.hdf.xml со ссылками на ваши собственные шрифты.
Рисунок 2. Пример файла webfont.hdf.xml
<дел>
В этом примере используется Шрифт Ното Санс. Вы можете использовать несколько шрифтов, создав дополнительные
<ссылка>
ссылок в этом файле. Оболочка деления будет удалена, когда создание файлов HTML, а содержимое будет вставлено в элемент - В каталоге com.example.html5-webfont создайте подкаталог с именем css.
- В новом подкаталоге css создайте файл с именем custom.css с
правила таблицы стилей, которые применяют пользовательское семейство шрифтов
body { семейство шрифтов: «Noto Sans», без засечек; }
В этом примере используется Noto Sans для всего содержимого тела. На практике вы обычно используете разные шрифты. для заголовков, основного содержимого, таблиц и т. д., создав дополнительные правила в файле CSS.
- В корневой каталог com.example.html5-webfont добавьте сценарий Ant.
(build_html5-webfont.xml), чтобы определить тип преобразования. Рисунок 4. Пример файла сборки: build_html5-webfont.xml
<проект> <целевое имя="dita2html5-webfont" зависит = "dita2html5-webfont.init, dita2html5"/> <целевое имя="dita2html5-webfont.init"> <имя свойства="args.hdf" location="${dita.plugin.com.example.html5-webfont.dir}/include/webfont.hdf.xml"/>
Результаты
Совет. Файлы для этого образца подключаемого модуля включены в каталог установки DITA-OT в docsrc/samples/plugins/com.example.html5-webfont/ и далее Гитхаб.
Каталог плагинов имеет следующую структуру и файлы:
com. example.html5-веб-шрифт ├── build_html5-webfont.xml ├── CSS │ └── custom.css ├── включить │ └── webfont.hdf.xml └── plugin.xml
Что делать дальше
- Запуск дита —install для установки плагина и создания html5-webfont доступная трансформация.
- Создайте выходные данные с новым типом преобразования, чтобы убедиться, что подключаемый модуль работает должным образом.
dita --input= my.ditamap --format=html5-webfont
- Уточните стили в файле custom.css, чтобы при необходимости настроить использование шрифта.
CSS font-family — бесплатный учебник для изучения HTML и CSS
CSS предоставляет несколько свойств шрифта , которые напрямую влияют на рендеринг текста. Свойство font-family
определяет , какой шрифт использовать.
Общие семейства шрифтов
Шрифты сгруппированы в 5 общих семейств:
-
шрифты с засечками
имеют маленькие линии в конце каждого символа -
без засечек
-
моноширинный
-
курсив
-
фантастика
скоропись
и фантазия
никогда не используются.
Поскольку свойство font-family
наследуется всеми дочерними элементами HTML, можно применить шрифт ко всему документу HTML, применив его к предку всех элементов HTML: элементу
.
body{ font-family: sans-serif;}
С этим правилом CSS веб-страница будет использовать шрифт без засечек определяется пользователем в его настройках.
Веб-безопасные шрифты
Проблема с использованием общих имен шрифтов заключается в том, что дизайн вашей веб-страницы будет зависеть от шрифта, установленного пользователем в его настройках.
Поскольку вы, вероятно, хотите, чтобы ваша веб-страница выглядела одинаково на любом компьютере, вам нужно определить специальный шрифт , который будет использоваться. Для этого просто используйте имя шрифта.
body{ семейство шрифтов: Arial;}
Ваша веб-страница будет использовать Arial при условии, что он установлен на компьютере пользователя . Если шрифт Arial недоступен на компьютере пользователя, он будет использовать шрифт с засечками браузера по умолчанию (обычно это Times).
Тем не менее,Arial — безопасный выбор, поскольку он установлен на всех компьютерах с Windows и Mac, а также на большинстве систем Linux. Вот почему Arial считается веб-безопасным шрифтом : вы можете смело использовать его в своем CSS и быть почти уверенным, что он будет установлен на компьютере пользователя.
Есть 9 безопасные веб-шрифты:
- Ариал
- Ариал Черный
- Комикс Санс MS
- Курьер Новый
- Грузия
- Воздействие
- Таймс Нью Роман
- Требушет MS
- Вердана
Применение списка шрифтов
Хотя использование любых из этих значений для свойства font-family
является безопасной ставкой, вы можете определить резервных значений , написав список семейств шрифтов :
body{ семейство шрифтов: Arial, Verdana, sans-serif;}
Определив несколько значений для семейства шрифтов
, браузер будет искать первое значение Arial
и использовать его.