Перезагрузка
Перезагрузка, набор изменений CSS для конкретных элементов в одном файле, запускает Bootstrap, чтобы обеспечить элегантную, последовательную и простую основу для развития.
Подход
Reboot основывается на Normalize, предоставляя многие элементы HTML с несколько самоуверенными стилями, используя только селекторы элементов. Дополнительная стилизация выполняется только с классами. Например, мы перезагружаем некоторые стили <table> для упрощения базовой линии, а позже предоставляем .table, .table-bordered и другие.
Вот наши рекомендации и причины выбора того, что следует переопределить в Reboot:
- Обновите некоторые значения браузера по умолчанию, чтобы использовать
remвместоemдля масштабируемого расстояния между компонентами. - Избегайте
margin-top. Вертикальные поля могут исчезнуть, что приведет к неожиданным результатам. Что еще более важно, одно направлениеmargin- это более простая ментальная модель. - Для упрощения масштабирования по размеру устройства в элементах блока следует использовать
remвместоmargin. - Сведите к минимуму объявления свойств, связанных со шрифтом
font, используя по возможности наследованиеinherit.
Параметры страницы по умолчанию
Элементы <html> и <body> обновлены, чтобы обеспечить лучшие значения по умолчанию для всей страницы. Более конкретно:
- The
box-sizingустанавливается глобально для каждого элемента, включая*::beforeи*::afterдляborder-box. Это гарантирует, что заявленная ширина элемента никогда не будет превышена из-за заполнения или границы. - Базовый размер шрифта
font-sizeне объявлен в<html>, но предполагается16px(по умолчанию в браузере).font-size: 1remприменяется к элементу<body>для быстрого масштабирования типов с помощью медиа-запросов, при этом соблюдая предпочтения пользователя и обеспечивая более доступный подход. <body>также устанавливает глобальноfont-family,line-heightиtext-align. Позже это наследуется некоторыми элементами формы, чтобы предотвратить несоответствие шрифтов.- Для безопасности
<body>имеет объявленный цвет фонаbackground-color, по умолчанию -#fff.
Стек собственных шрифтов
Веб-шрифты по умолчанию (Helvetica Neue, Helvetica и Arial) были удалены в Bootstrap 4 и заменены «стеком собственных шрифтов» для оптимального рендеринга текста на всех устройствах и ОС. Узнайте больше о стеках собственных шрифтов в этой статье Smashing Magazine.
$font-family-sans-serif:
// Safari для macOS и iOS (Сан-Франциско)
-apple-system,
// Chrome <56 для macOS (Сан-Франциско)
BlinkMacSystemFont,
// Windows
"Segoe UI",
// Android
Roboto,
// Базовый резервный веб-сайт
"Helvetica Neue", Arial,
// Linux
"Noto Sans",
"Liberation Sans",
// Резервный вариант без засечек
sans-serif,
// Emoji шрифты
"Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !default;
Обратите внимание, что, поскольку стек шрифтов включает шрифты эмодзи, многие распространенные символы Unicode символов/дингбатов будут отображаться как разноцветные пиктограммы. Их внешний вид будет различаться в зависимости от стиля, используемого в собственном шрифте эмодзи браузера/платформы, и на них не будут влиять никакие стили CSS color.
Это семейство шрифтов font-family применяется к <body> и автоматически наследуется во всем Bootstrap. Чтобы переключить глобальное семейство шрифтов font-family, обновите $font-family-base и перекомпилируйте Bootstrap.
Заголовки и абзацы
Все элементы заголовка - например, <h1> и <p> сбрасываются, чтобы удалить их margin-top. В заголовки добавлены margin-bottom: .5rem и параграфы margin-bottom: 1rem для удобного размещения.
| Заголовок | Пример |
|---|---|
<h1></h1>
|
h1. Заголовок Bootstrap |
<h2></h2>
|
h2. Заголовок Bootstrap |
<h3></h3>
|
h3. Заголовок Bootstrap |
<h4></h4>
|
h4. Заголовок Bootstrap |
<h5></h5>
|
h5. Заголовок Bootstrap |
<h6></h6>
|
h6. Заголовок Bootstrap |
Списки
Во всех списках <ul>, <ol> и <dl> удалены их margin-top и margin-bottom: 1rem. Вложенные списки не имеют margin-bottom.
- All lists have their top margin removed
- And their bottom margin normalized
- Nested lists have no bottom margin
- This way they have a more even appearance
- Particularly when followed by more list items
- The left padding has also been reset
- Here’s an ordered list
- With a few list items
- It has the same overall look
- As the previous unordered list
Для упрощения стиля, четкой иерархии и лучшего интервала в списках описаний обновлены поля margin. <dd> сбрасывает margin-left в 0 и добавляет margin-bottom: .5rem. <dt> выделены жирным шрифтом.
- Списки описаний
- Список описаний идеально подходит для определения терминов.
- Срок
- Определение термина.
- Второе определение того же термина.
- Другой термин
- Определение этого другого термина.
Предварительно отформатированный текст
Элемент <pre> сбрасывается, чтобы удалить его margin-top и использовать единицы rem для его margin-bottom.
.example-element {
margin-bottom: 1rem;
}
Таблицы
Таблицы немного скорректированы для стиля <caption>, сворачивания границ и обеспечения единообразия text-align повсюду. Дополнительные изменения границ, отступов и прочего связаны с классом .table.
| Заголовок таблицы | Заголовок таблицы | Заголовок таблицы | Заголовок таблицы |
|---|---|---|---|
| Ячейка таблицы | Ячейка таблицы | Ячейка таблицы | Ячейка таблицы |
| Ячейка таблицы | Ячейка таблицы | Ячейка таблицы | Ячейка таблицы |
| Ячейка таблицы | Ячейка таблицы | Ячейка таблицы | Ячейка таблицы |
Формы
Для упрощения базовых стилей были перезагружены различные элементы формы. Вот некоторые из наиболее заметных изменений:
<fieldset>не имеют границ, отступов или полей, поэтому их можно легко использовать в качестве оберток для отдельных входов или групп входов.<legend>, как и наборы полей, также были переработаны, чтобы отображаться как своего рода заголовки.- Для тегов
<label>установлено значениеdisplay: inline-blockчтобы можно было применитьmargin. <input>,<select>,<textarea>и<button>в основном обрабатываются Normalize, но Reboot удаляет ихmarginи устанавливаетline-height: inheritтоже.<textarea>изменены так, чтобы их размер можно было изменять только по вертикали, поскольку изменение размера по горизонтали часто “ломает” макет страницы.- Элементы кнопок
<button>и<input>имеютcursor: pointerкогда:not(:disabled).
Эти и другие изменения показаны ниже.
Указатели на кнопках
Перезагрузка включает усовершенствование для role="button", чтобы изменить курсор по умолчанию на pointer. Добавьте этот атрибут к элементам, чтобы указать, что элементы интерактивны. Эта роль не обязательна для элементов <button>, которые имеют собственное изменение cursor.
<span role="button" tabindex="0">Кнопка элемента без кнопки</span>Разные элементы
Адрес
Элемент <address> обновлен для сброса стиля шрифта font-style браузера по умолчанию с курсивного italic на нормальный normal. line-height теперь унаследован, и был добавлен margin-bottom: 1rem. <address> предназначены для представления контактной информации ближайшего предка (или всего объема работы). Сохраните форматирование, заканчивая строки символом <br>.
1355 Market St, Suite 900
San Francisco, CA 94103
P: (123) 456-7890 ФИО
first.last@example.com
Цитата
По умолчанию margin для цитат составляет 1em 40px, поэтому мы сбрасываем ее на 0 0 1rem для большей согласованности с другими элементами.
A well-known quote, contained in a blockquote element.
Строковые элементы
Элемент <abbr> получает базовый стиль, чтобы выделить его среди текста абзаца.
Резюме
По умолчанию cursor в сводке является text, поэтому мы сбрасываем его на pointer, чтобы указать, что с элементом можно взаимодействовать, щелкнув по нему.
Некоторые детали
Подробнее о деталях.
Еще больше деталей
Вот еще более подробная информация о деталях.
Атрибут HTML5 [hidden]
HTML5 добавляет новый глобальный атрибут с именем [hidden], который имеет стиль display: none по умолчанию. Заимствуя идею из PureCSS, мы улучшаем это значение по умолчанию, сделав [hidden] { display: none !important; }, чтобы предотвратить случайное переопределение его display. Хотя IE10 изначально не поддерживает [hidden], явное объявление в нашем CSS решает эту проблему.
<input type="text" hidden>
Несовместимость jQuery
[hidden] несовместим с методами jQuery $(...).hide() и $(...).show(). Поэтому в настоящее время мы не особо поддерживаем [hidden] по сравнению с другими методами управления display элементов.
Чтобы просто переключить видимость элемента, то есть его display не изменяется, и элемент все еще может влиять на поток документа, используйте класс .invisible вместо этого.