9.3 KiB
title | localeTitle |
---|---|
Breakpoints | Контрольные точки |
обзор
Точка перехвата CSS - это особая точка, в которой изменяется макет веб-сайта, на основе медиа-запроса становится активным.
Как правило, вы указываете точку останова, когда хотите повторно адаптировать макет сайта к размеру видового экрана браузера; в основном, до ширины окна просмотра.
Например, если контент вашего сайта отлично смотрится в узком окне просмотра (например, в браузере смартфонов), но он начинает плохо выглядеть на больших экранах (например, размер шрифтов слишком мал и его трудно читать), тогда вы может захотеть ввести новую точку останова для больших экранов, что делает шрифты больше:
Точки перехвата CSS могут считаться сердцем отзывчивого веб-дизайна, потому что они определяют, как ведет себя контент или организуется различная ширина / масштаб устройства, позволяющий пользователю показать наилучший макет для пользователя.
Настройка точек останова
Точки останова в целом устанавливаются на основе любого из следующих.
- Точки останова на основе ширины устройства.
- Точки останова на основе контента.
Точки останова на основе ширины устройства
Совершенно очевидно, что все наши устройства имеют одинаковые ширины и размеры экрана. Теперь дизайнерское решение включает набор конкретных устройств и кодирует правила css соответственно. У нас уже достаточно устройств для беспокойства, и когда новый выходит с другой шириной, возврат к вашему CSS и добавление новой контрольной точки снова требует много времени.
Вот пример
/* ----------- iPhone 6, 6S, 7 and 8 ----------- */
/* Portrait */
@media only screen
and (min-device-width: 375px)
and (max-device-width: 667px)
and (-webkit-min-device-pixel-ratio: 2)
and (orientation: portrait) {
}
/* Landscape */
@media only screen
and (min-device-width: 375px)
and (max-device-width: 667px)
and (-webkit-min-device-pixel-ratio: 2)
and (orientation: landscape) {
}
/* ----------- Google Pixel ----------- */
/* Portrait */
@media screen
and (device-width: 360px)
and (device-height: 640px)
and (-webkit-device-pixel-ratio: 3)
and (orientation: portrait) {
}
/* Landscape */
@media screen
and (device-width: 360px)
and (device-height: 640px)
and (-webkit-device-pixel-ratio: 3)
and (orientation: landscape) {
}
При таком подходе вы получите огромный список медиа-запросов.
Точки останова на основе контента
Это наиболее предпочтительный выбор при составлении или написании правил точки останова. Потому что упростить настройку вашего контента в соответствии с конкретным макетом только тогда, когда требуется изменение.
@media only screen (min-width: 768px){
...
}
Эта точка останова означает, что CSS будет применяться, когда ширина устройства составляет 768 пикселей и выше.
Вы также можете установить диапазон с точками останова, поэтому CSS будет применяться только в этих пределах.
@media only screen and (min-width: 768px) and (max-width: 959px){
...
}
Заметка Всегда старайтесь создавать точки останова на основе собственного контента, а не устройств. Разделите их на логическую ширину, а не на произвольную ширину, и сохраните их на управляемом числе, поэтому изменение остается простым и понятным.
Точки прерывания CSS полезны, когда вы хотите обновлять стили на основе размера экрана. Например, с устройства размером 1200px и выше, используйте font-size: 20px;
, либо используйте font-size: 16px;
,
То, с чего мы начали, - это ширина более 1200 пикселей, общая ширина экрана ноутбука. Вы также заметили, что мы упоминали «больше, чем», что означает, что мы в некотором роде используем что-то вроде утверждения « если-то ».
Давайте превратим его в код CSS:
.text1 {
font-size: 16px;
}
@media (min-width: 1200px) {
.text1 {
font-size: 20px;
}
}
Для нашего удобства сначала .text1
основной стиль .text1
... затем мы укажем правила @media
.
Совет . Вы можете увидеть на общей CSS-платформе под названием «Bootstrap», что они приняли «минимальную ширину» и в своем Bootstrap v4.0, по сравнению с их старым Bootstrap v3.0, используя «max-width» и down , Это только предпочтение , и нет ничего плохого в том, чтобы сказать « этот размер и меньше» по сравнению с « этим размером и больше».
Совершенно нормально использовать @media (max-width) {}
. Вот пример:
.text1 {
font-size: 20px;
}
@media (max-width: 1199px) {
font-size: 16px;
}
// Normal, basic styles
// that look great on small screens
// but not on bigger screens
body {
font-size: 16px;
}
// Define a new breakpoint, with a media query.
// In this case, for when the viewport's width
// is at least 512px wide.
@media (min-width: 512px) {
body {
font-size: 20px;
}
}
Точки останова, основанные на содержимом, в отличие от устройства, менее сложны. Вот простой фрагмент code 700px
который запускается, когда ширина устройства code 700px
примерно по размеру экрана смартфона
@media only screen and (min-width: 700px) {
something {
something: something;
}
}
Вы также можете установить минимальную и максимальную ширину, что позволит вам экспериментировать с различными диапазонами. Это примерно триггер между smar-телефоном и большими размерами рабочего стола и монитора
@media only screen and (min-width: 700px) and (max-width: 1500px) {
something {
something: something;
}
}