Ширина блока: Ширина блока | htmlbook.ru

Содержание

Ширина блока | htmlbook.ru

Любой блочный элемент состоит из набора свойств, подобно капустным листам накладываемых друг на друга. Основой блока выступает его контент (это может быть текст, изображение и др.), ширина которого задаётся свойством width, а высота через height; вокруг контента идут поля (padding), они создают пустое пространство от контента до внутреннего края границ; затем идут собственно сами границы (border) и завершают блок отступы (margin), невидимое пустое пространство от внешнего края границ. Ширина блока это комплексная величина и складывается из нескольких значений свойств:

  • width — ширина контента, т.е. содержимого блока;
  • padding-left и padding-right — поле слева и справа от контента;
  • border-left и border-right — толщина границы слева и справа;
  • margin-left и margin-right — отступ слева и справа.

Какие-то свойства могут отсутствовать и в этом случае на ширину не оказывают влияние. Общая ширина показана на рис. 1 в виде чёрной пунктирной линии.

Рис. 1. Ширина блока

Если значение width не задано, то оно по умолчанию устанавливается как auto. В этом случае ширина блока будет занимать всю доступную ширину при сохранении значений полей, границ и отступов. Под доступной шириной в данном случае подразумевается ширина контента у родительского блока, а если родителя нет, то ширина контента браузера.

Допустим, для слоя написан следующий стиль.

width: 300px; /* Ширина слоя */
margin: 7px; /* Значение отступов */
border: 4px solid black; /* Параметры границы */
padding: 10px; /* Поля вокруг текста */

Ширина слоя согласно этой записи будет равна 342 пиксела, эта величина получается складыванием значения ширины контента плюс отступ слева, граница слева и поле слева, плюс поле справа, граница справа и отступ справа. Суммируем все числа.

Ширина = 300 + 7 + 7 + 4 + 4 + 10 + 10 = 342

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

Алгоритм блочной модели

Как уже упоминалось, ширина блока формируется из ширины контента и значений полей, границ и отступов. В браузере Internet Explorer в режиме совместимости алгоритм меняется автоматически и ширина всего блока устанавливается равной width. Остальные браузеры так просто не меняют алгоритм, к тому же вы знаете, что режим совместимости это зло. В CSS3 есть замечательное свойство box-sizing, которое нам и пригодится. При значении border-box ширина начинает включать поля и границы, но не отступы. Таким образом, подключая box-sizing со значением border-box к своему стилю, мы можем задавать ширину в процентах и спокойно указывать border и padding, не боясь, что изменится ширина блока. К сожалению, с этим свойством связана небольшая проблема, как обычно относящаяся к браузерам — не все браузеры его понимают. Радует, что браузеры хотя бы поддерживают специфические для каждого браузера свойства. В табл. 1 приведена поддержка браузерами.

Табл. 1. Поддержка браузерами свойства box-sizing
БраузерInternet Explorer
Chrome
OperaSafariFirefox
Версия8.0+2.0+7.0+3.0+1.0+
Свойствоbox-sizing-webkit-box-sizingbox-sizing-webkit-box-sizing-moz-box-sizing

Как видно из таблицы, в свойствах разброд и шатание, поэтому придется делать гибрид и указывать все три свойства (пример 1).

Пример 1. Ширина блока

HTML5CSS3IECrOpSaFx

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8" />
  <title>Ширина блока</title>
  <style type="text/css">
   div { 
    width: 100%; /* Ширина */
    background: #fc0; /* Цвет фона */
    padding: 20px; /* Поля */
    -moz-box-sizing: border-box; /* Для Firefox */
    -webkit-box-sizing: border-box; /* Для Safari и Chrome */
    box-sizing: border-box; /* Для IE и Opera */
   }
  </style>
 </head>
 <body>
  <div>Ширина слоя 100%</div>
 </body>
</html>

Данный пример будет работать во всех браузерах, указанных в табл. 1, однако невалиден в CSS3 из-за применения нестандартных свойств начинающихся на -moz и -webkit. Ширина блока составляет 100% с учетом значений padding. Без свойства box-sizing в браузере появится горизонтальная полоса прокрутки.

Вложенные слои

Использование свойства box-sizing всем хорошо, кроме того, что не работает в старых версиях IE. Если вы верстаете сайт с учетом IE7 и IE6, вам подойдет старый проверенный метод с вложением слоев. Идея простая — для внешнего блочного элемента задаётся только необходимая ширина, а для вложенного блока всё остальное — поля, границы и отступы. Поскольку по умолчанию ширина блока равна доступной ширине родителя, получится, что блоки в каком-то смысле накладываются друг на друга, при этом фактическая ширина такого комбинированного элемента будет чётко задана. В примере 2 показано использование вложенных слоев.

Пример 2. Вложенные слои

HTML5CSS 2.1IECrOpSaFx

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8" />
  <title>Ширина блока</title>
  <style>
   .wrap { 
    width: 50%; /* Ширина */
   }
   .wrap div {
    background: #fc0;
    margin: 10px;
    padding: 20px;
    border: 1px solid #000;
   }
  </style>
 </head>
 <body>
  <div>
   <div>
    Ширина слоя 100%
   </div>
  </div>
 </body>
</html>

Результат данного примера показан на рис. 2.

Рис. 2. Ширина блока в процентах

Преимуществом вложенных слоев является использование отступов (box-sizing их не учитывает), универсальность метода, также то, что фон по желанию можно добавлять к одному или другому слою. Тем самым несколько меняется внешний вид элементов, это особенно актуально при включении фоновых рисунков. Из недостатков метода можно отметить включение дополнительного блока, который усложняет структуру кода, особенно при частом применении метода. Но это можно считать мелочью по сравнению с преимуществами.

Умная адаптация ширины блочных элементов на чистом CSS 2.0 / Хабр

Верстая очередной проект (или ещё только проектируя макетную сетку) многие сталкивались с дилеммой — использовать фиксированную ширину макета или «резиновую» сетку, адаптируемую под размер окна браузера.

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

Фиксированная ширина макетной сетки

Вёрстку загоняют в горизонтальный габарит 960—980 пикселей (чтобы на большинстве устройств в большинстве разрешений всё входило), что при больших горизонтальных размерах окна выглядит как-то зябко — тонкая вертикальная полоса полезного содержимого страницы и огромные бесполезные поля неиспользуемого пространства по бокам.
«Резиновая» макетная сетка по ширине окна

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

Хочу предложить нехитрый вариант решения — ограничить минимальный горизонтальный размер фиксированным значением в пикселях, а максимальный сделать относительным в процентном соотношении к ширине окна. Это очень банально решается простыми средствами ещё 2 версии спецификации CSS.

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

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


Создаём контейнер макета:
<html>
  <head>
    ...
  </head>
  <body>
    <div>
      ...
    </div>
  </body>
</html>

Оформляем его незатейливым кодом стиля:
div.page-container {
  min-width: 960px;
  max-width: 75%;
  margin: 0 auto;
  padding: 0;
  }

Однако этого решения кому-то может показаться мало в силу того что при очень больших горизонтальных размерах окна опять проявляются проблемы с длиной строк. Это решается настолько же простым дополнительным приёмом: создание дополнительного внешнего контейнера внутри уже описанного и ограничение его максимальной ширины фиксированным значением (мне субъективно кажется, что лучше всего подходят значния в диапазоне 1400—1600 пикселей). Опять же используем лишь средства CSS 2.0. Такое решение вместо предложенного в первом комментарии простого добавления ширины в процентах для исходного контейнера будет работать ещё и в IE, который вплоть до 9 версии не понимает одновременного указания значений.

Дополняем HTML:

<html>
  <head>
    ...
  </head>
  <body>
    <div>
      <div>
        ...
      </div>
    </div>
  </body>
</html>

И немного меняем CSS:
div.page-container {
  max-width: 75%;
  min-width: 960px;
  margin: 0 auto;
  padding: 0;
  }

div.page-container-inner {
  min-width: 960px;
  max-width: 1600px;
  margin: 0 auto;
  padding: 0;
  }

Как видите — решение предельно просто и достаточно универсально, может применяться для любых блочных элементов.

Учебник CSS 3. Статья «Размеры блочных элементов в CSS»

Эта объемная статья учебника будет посвящена важным темам, задача которых заключается в том, чтобы расставить по полочкам методы работы с блочными элементами, объянить читателю для чего применяется изменение модели вычисления ширины и высоты элементов, как управлять переполнением блочных элементов, и как работать с минимальными и максимальными размерами элементов.

При изучении блочной модели CSS мы разобрали, что свойства width и height устанавливают ширину и высоту внутренней области элемента (content area), которая может содержать текст, изображения и прочие элементы.

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

Рис. 99 Схема вычисления общей ширины и высоты элементов.

Общая ширина элемента вычисляется по формуле:

width (ширина) + padding-left (левый внутренний отступ) + padding-right (правый внутренний отступ) + border-left (левая граница) + border-right (правая граница).

Общая высота элемента вычисляется по формуле:

height (высота) + padding-top (верхний внутренний отступ) + padding-bottom (нижний внутренний отступ) + border-top (верхняя граница) + border-bottom (нижняя граница).

Допустим, у нас есть следующие стили для элемента <div>:

div {
	width: 150px; /* устанавливаем ширину элемента */
	height: 150px; /* устанавливаем высоту элемента */
	padding: 10px; /* устанавливаем внутренние отступы элемента */
	border: 5px; /* устанавливаем границы элемента */
}

Для размещения элемента <div> браузеру необходимо подготовить следующее пространство:

Общая ширина элемента:

150 пикселей (пользовательское значение ширины) + 10 пикселей (левый внутренний отступ) + 10 пикселей (правый внутренний отступ) + 5 пикселей (левая граница) + 5 пикселей (правая граница) = 180 пикселей.

Общая высота элемента:

150 пикселей (пользовательское значение высоты) + 10 пикселей (нижний внутренний отступ) + 10 пикселей (верхний внутренний отступ) + 5 пикселей (нижняя граница) + 5 пикселей (верхняя граница) = 180 пикселей.

И так, мы с Вами рассмотрели, как классически происходит вычисление общей ширины и высоты элементов. Минусы этой модели заключаются в том, что вам необходимо проводить математические вычисления, чтобы понять какую действительно ширину, либо высоту имеет тот, или иной элемент. Удобно ли это?

Изменение модели вычисления ширины и высоты элементов

С выходом стандарта CSS 3 добавлено свойство box-sizing, оно позволяет изменить, применяемую по умолчанию CSS модель, с помощью которой вычисляются ширина и высота элементов.

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

<!DOCTYPE html>
<html>
<head>
	<title>Пример вычисления ширины и высоты элементов</title>
<style> 
div {
display: inline-block; /* устанавливаем элементы <div> как блочно-строчные (выстраиваем в линейку) */
width: 25%; /* устанавливаем ширину элемента */
height: 100px; /* устанавливаем высоту элемента */
} 
.test {
background-color: red;  /* задаем цвет заднего фона */
}
.test2 {
background-color: green;  /* задаем цвет заднего фона */
}
.test3 {
background-color: blue;  /* задаем цвет заднего фона */
}
.test4 {
background-color: yellow;  /* задаем цвет заднего фона */
}
</style>
</head>
	<body>
		/* обязательно прочтите пояснение ниже */
		<div class = "test"></div><div class = "test2"></div><div class = "test3"></div><div class = "test4"></div> 
	</body>
</html>

Обратите внимание на важный момент — все четыре блока размещены в одну строчку.


Это очень тонкий момент, дело в том, что когда вы используете display: inline-block браузер расценивает переносы строки как пробельный символ, и как следствие, добавляет после каждого блока 3-4px пустого пространства в зависимости от браузера и шрифта пользователя. По сути это является междусловным интервалом, так как блок расценивается в данном случае как слово. Может на данном этапе этот момент для вас не до конца понятен, просто запомните его, чтобы в последствии случайно не потерять пару часов, когда у вас будет «съезжать» какой-то блок, или список в панели навигации из-за вдруг появившихся «не понятно откуда пикселей». Я человек простой: вижу непонятные пиксели при display: inline-block – пишу элементы в линейку без пробелов.


В результате у нас должно получиться четыре разноцветных блока, расположенных в линейку:

Рис.100 Пример вычисления ширины и высоты элементов.

А теперь техническое задание поменялось, и Вам необходимо к каждому нечетному блоку добавить сплошную границу справа размером 5px. Для этого мы создадим следующий стиль:

div:nth-child(odd) { /* выбираем каждый нечетный блок внутри родительского элемента */
border-right: 5px solid; /* добавляем сплошную границу справа размером 5px */
}

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

<!DOCTYPE html>
<html>
<head>
	<title>Пример вычисления ширины и высоты элементов в процентах</title>
<style> 
div {
display: inline-block; /* устанавливаем элементы <div> как блочно-строчные (выстраиваем в линейку) */
width: 25%; /* устанавливаем ширину элемента */
height: 100px; /* устанавливаем высоту элемента */
}
div:nth-child(odd) { /* выбираем каждый нечетный блок внутри родительского элемента */
border-right: 5px solid; /* добавляем сплошную границу справа размером 5px */
}
.test {
background-color: red;  /* задаем цвет заднего фона */
}
.test2 {
background-color: green;  /* задаем цвет заднего фона */
} 
.test3 {
background-color: blue;  /* задаем цвет заднего фона */
}
.test4 {
background-color: yellow;  /* задаем цвет заднего фона */
}
</style>
</head>
	<body>
		<div class = "test"></div><div class = "test2"></div><div class = "test3"></div><div class = "test4"></div> 
	</body>
</html>

Как вы можете заметить на изображении ниже, нас ждет разочарование, так как наш макет «поплыл»:

Рис. 101 Пример вычисления ширины и высоты элементов в процентах.

Какие у нас есть варианты, чтобы исправить наш макет?

Варианта два:

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

В нашем случае я считаю, что необходимо выбрать второй вариант:

<!DOCTYPE html>
<html>
<head>
<title>Пример использования свойства box-sizing</title>
<style> 
div {
display: inline-block; /* устанавливаем элементы <div> как блочно-строчные (выстраиваем в линейку) */
width: 25%; /* устанавливаем ширину элемента */
height: 100px; /* устанавливаем высоту элемента */
box-sizing: border-box; /* изменяем модель вычисления ширины и высоты элементов */
}
div:nth-child(odd) {
border-right: 5px solid; /* к каждому нечетному блоку добавляем сплошную границу справа черного цвета  размером 5px. */
}
.test {
background-color: red;  /* задаем цвет заднего фона */
}
.test2 {
background-color: green;  /* задаем цвет заднего фона */
}
.test3 {
background-color: blue;  /* задаем цвет заднего фона */
}
.test4 {
background-color: yellow;  /* задаем цвет заднего фона */
}
</style>
</head>
<body>
	<div class = "test"></div><div class = "test2"></div><div class = "test3"></div><div class = "test4"></div> 
</body>
</html>

Мы использовали CSS свойство box-sizing со значением border-box, что позволило нам изменить модель вычисления ширины и высоты элементов.


Отличительная особенность данной модели заключается в том, что значения свойства ширины (width) и высоты (height) включают в себя содержание элемента, границы (border) и внутренние отступы (padding).


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

Рис.102 Пример использования свойства box-sizing.

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

<!DOCTYPE html>
<html>
<head>
	<title>Пример изменения модели вычисления ширины и высоты элементов</title>
<style> 
div {
display: inline-block;  /*  устанавливаем элементы <div> как блочно-строчные (выстраиваем в линейку) */
width: 150px; /* устанавливаем ширину блока */
height: 150px;  /* устанавливаем высоту блока */
margin: 10px;  /* устанавливаем внешний отступ для всех сторон */
padding: 10px;  /* устанавливаем внутренний отступ для всех сторон */
border: 10px solid orange;  /* устанавливаем сплошную границу 10px оранжевого цвета */
background: khaki;
} 
.test {
box-sizing: content-box; /* ширина и высота элемента включают в себя только содержание элемента (по умолчанию) */
}
.test2 {
box-sizing: border-box; /* ширина и высота элемента включают в себя содержание элемента, границы (border) и внутренние отступы (padding) */
}
</style>
</head>
	<body>
		<div class = "test">content-box</div><div class ="test2">border-box</div>
	</body>
</html>

Значение content-box свойства box-sizing является значением по умолчанию и производит расчёт общей ширины и высоты элемента по классической схеме. На примере ширины:

150 пикселей (пользовательское значение ширины) + 10 пикселей (левый внутренний отступ) + 10 пикселей (правый внутренний отступ) + 10 пикселей (левая граница) + 10 пикселей (правая граница) = 190 пикселей.

Что касается второго элемента, к которому мы применили свойство box-sizing со значением border-box, то пользовательское значение ширины и высоты элемента уже включают в себя содержание элемента, границы (border) и внутренние отступы (padding). В большинстве случаев применение свойства box-sizing со значением border-box предпочтительно на страницах, так как делает очевидным конечные размеры элемента и позволяет избежать некоторых непредвиденных ситуаций рассмотренных выше.

Результат нашего примера:

Рис. 103 Пример изменения модели вычисления ширины и высоты элементов (свойство box-sizing).

Управление переполнением блочных элементов

В процессе верстки у вас будут возникать такие ситуации, когда содержимое элемента будет отображаться за пределами границ элемента. По умолчанию браузер отображает такое содержимое (переполнение элемента отображается), что в некоторых случаях приводит к визуальным ошибкам. За такое поведение браузера отвечает CSS свойство overflow. Рассмотрим его возможные значения:

ЗначениеОписание
visibleПереполнение не обрезается, содержимое выходит за пределы размеров элемента. Это значение по умолчанию.
hiddenПереполнение обрезается (контент, который выходит за размеры будет невидимым).
scrollПереполнение обрезается, но добавляется полоса прокрутки, позволяющая увидеть содержимое, которое выходит из заданных размеров.
autoЕсли переполнение обрезается, то полоса прокрутки будет добавлена автоматически, чтобы увидеть содержимое, которое выходит из заданных размеров.

Давайте рассмотрим следующий пример:

<!DOCTYPE html>
<html>
<head>
<title>Пример управления переполнением элемента</title>
<style> 
div {
display: inline-block;  /*  устанавливаем элементы <div> как блочно-строчные (выстраиваем в линейку)  */
width: 125px; /* устанавливаем ширину блока */
height: 100px;  /* устанавливаем высоту блока */
padding: 5px;  /* устанавливаем внутренний отступ для всех сторон */
border: 1px solid orange;  /* устанавливаем сплошную границу 1px оранжевого цвета */
vertical-align: top; /* верх элемента выравнивается по верху самого высокого элемента в строке (вертикальное позиционирование) */
}
.test {
overflow: visible; /* переполнение не обрезается */
}
.test2 {
overflow: hidden; /* переполнение обрезается */
}
.test3 {
overflow: scroll; /* переполнение обрезается, но добавляется полоса прокрутки */
}
.test4 {
overflow: auto; /* если переполнение обрезается, то полоса прокрутки будет добавлена автоматически */
}
</style>
</head>
<body>
	<div class = "test"><p>overflow: visible</p>Съешь же ещё этих мягких французских булок да выпей чаю.</div>
	<div class = "test2"><p>overflow: hidden</p>Съешь же ещё этих мягких французских булок да выпей чаю.</div>
	<div class = "test3"><p>overflow: scroll</p>Съешь же ещё этих мягких французских булок да выпей чаю.</div>
	<div class = "test4"><p>overflow: auto</p>Съешь же ещё этих мягких французских булок да выпей чаю.</div>
</body>
</html>

В данном примере мы разместили четыре блока фиксированной ширины и высоты, для которых указали различные значения CSS свойства overflow:

  • Первый блок (значение visible) – содержимое выходит за границы элемента (значение по умолчанию).
  • Второй блок (значение hidden) – содержимое, которое переполняет элемент обрезается.
  • Третий блок (значение scroll) – переполнение обрезается, но добавляется полоса прокрутки.
  • Четвертый блок (значение auto) – как и при значении scroll, только полоса прокрутки будет добавлена автоматически, если произойдет переполнение блока по определенной оси (x — горизонтальной, либо y — вертикальной), а не отображается на странице постоянно.

Результат нашего примера:

Рис. 104 Пример управления переполнением элемента.

Переполнение по определённой оси

С выходом стандарта CSS 3 были добавлены свойства, которые способны управлять по отдельности горизонтальным переполнением (ось x) – overflow-x и вертикальным переполнением (ось y) – overflow-y. В отличии от свойства overflow, данные свойства отвечают только за одну ось (x, либо y) при этом значения и синтаксис аналогичен свойству overflow (таблица выше).

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

<!DOCTYPE html>
<html>
<head>
	<title>Пример управления переполнением элемента по горизонтальной оси</title>
<style> 
pre {
width: 300px; /* устанавливаем ширину элемента */
overflow-x: scroll; /* переполнение обрезается, но добавляется полоса прокрутки */
background-color: orange; /* задаем цвет заднего фона */
}
</style>
</head>
	<body>
		<pre>
			Съешь же ещё этих мягких французских булок да выпей чаю. 
		</pre>
	</body>
</html>

В данном примере мы использовали элемент <pre>, который сохраняет все пробелы и переносы строк (текст может выходить из отведённой области), что нам и помогло продемонстрировать возможности свойства overflow-x. В нашем случае текст вышел за пределы ширины размера элемента <pre> и браузер добавил горизонтальный бегунок прокрутки, что нам и требовалось.

Результат нашего примера:

Рис. 105 Пример управления переполнением элемента по горизонтальной оси.

Минимальные и максимальные значения ширины и высоты блочного элемента

Заключительная тема этой статьи, которую необходимо освоить это указание минимальных и максимальных размеров для блочных элементов.

CSS, помимо явного указания значений ширины и высоты элементов (свойства width и height) предлагает такие свойства, которые позволяют указать для блочных элементов их минимальные, либо максимальные значения:

  • min-width (устанавливает минимальную ширину элемента).
  • max-width (устанавливает максимальную ширину элемента).
  • min-height (устанавливает минимальную высоту элемента).
  • max-height (устанавливает максимальную высоту элемента).

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

<!DOCTYPE html>
<html>
<head>
	<title>Минимальная высота и максимальная ширина для блочных элементов</title>
<style> 
:root { /* псевдокласс :root определяет корневой элемент документа */
background-color: black; /* задаем цвет заднего фона */
}
html {
height:100%; /* задаем высоту элемента в процентах */
background-color: white; /* задаем цвет заднего фона */
}
body {
margin: 0 auto; /* задаем внешние отступы элемента (0 для верха и низа, автоматически слева и справа) */
max-width: 800px; /* задаем максимальную ширину элемента в пикселях */
height: 100%; /* задаем высоту элемента в процентах */
}
div {
min-height: 100%; /* задаем минимальную высоту элемента в процентах */
}
</style>
</head>
	<body>
		<div>
		</div>
	</body>
</html>

Какие приёмы CSS надо обязательно уяснить из этого примера:

  1. Как установить высоту элемента 100% при любом разрешении?

    Для начала мы должны установить для родителя элемента размер высоты 100%. В нашем случае необходимо установить 100% для элементов <html> и <body>, и только после этого мы устанавливаем для нашего блока размер минимальной высоты 100% (min-height). В итоге это приводит к тому, что у нас даже пустой блок растягивается на весь экран.
  2. Как горизонтально центрировать страницу?

    Для этого необходимо установить внешние отступы элемента сверху и снизу равными 0 (нулю), а слева и справа установить как auto (автоматически):
    margin: 0 auto;
    
    В нашем случае мы центрируем страницу, используя такой стиль для элемента <body>.
    Кроме того, мы указываем для элемента <body> максимальное значение ширины равной 800px (если разрешение экрана не будет вмещать 800px, то значение будет равно размеру экрана браузера (меньше этого числа), но элемент в котором установлен максимальный размер не может растянуться больше этого числа).
    Например, если бы мы указали min-width: 100px, то это бы означало, что элемент не может быть меньше чем 100px (если экран будет меньше, то браузер добавит полосу прокрутки).
  3. Как установить стиль, который будет приоритетней элемента <html>?

    Псевдокласс :root, как и селектор типа html делают одно и тоже (выбирают одни и те же элементы), но псевдокласс :root обладает более высокой специфичностью (болеее значимый при определении стиля). Вы можете использовать такой прием в будущем для установки изображений в качестве заднего фона. Подробное изучение работы с задним фоном мы рассмотрим далее в учебнике в статье «Работа с фоном элемента в CSS».

Результат нашего примера приведен на изображении ниже:

Рис. 106 Пример установки минимальной высоты и максимальной ширины для блочных элементов.

Вопросы и задачи по теме

Перед тем как перейти к изучению следующей темы пройдите практическое задание:

  • Для выполнения задания вам понадобится скачать архив и скопировать содержимое архива (HTML файл) в любую папку на вашем жестком диске:

  • Используя полученные знания составьте следующий документ, посвященный белому тигру (внимательно изучите страницу перед выполнением):

    Практическое задание № 26.

    Обратите внимание, что при уменьшении размера окна браузера страница принимает следующий вид:

    Практическое задание № 26 (при уменьшении размеров окна).

    Обращаю Ваше внимание, что для выполнения этого задания Вам необходимы знания из прошлых статей учебника.

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


© 2016-2020 Денис Большаков, замечания и предложения по работе сайта Вы можете направить по адресу [email protected]

сибит в блоках 100-300 мм и кирпичи другой толщины, выбор габаритов газобетона для строительства стен

Схема расчета

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

  1. Для определения общей площади стены надо перемножить длину и высоту, потом вычесть от полученного значения размеры дверных или оконных проемов, которые вычисляются по этой же схеме. Например: простенок длиной 10 м, высотой — 3 м, общая площадь составляет 30 м. кв. В конструкции присутствует один проем размером 1*2 м. окончательное число будет таким: 28 м. кв. Для стен со сложной формой действует аналогичный принцип расчета.
  2. Чтобы определить число газоблоков, придется поделить полученную площадь будущей перегородки на боковые параметры блока.

Блок стеновой (сибит) из газобетона 300 мм

ГОСТ 31360-2007

Размер блока: 625*300*250 мм

Класс газобетона по прочности: В 2,5

Марка газобетона по средней плотности: D600 

Количество блоков в поддоне: 16 шт.

Вес поддона: 585 кг

Объем поддона: 0,75 м.куб.

Размер поддона с продукцией: 625*1000 мм

Количество кв.м. в поддоне: 2,5

Что входит в эту цену: 1 поддонсибита любой толщины (100, 150, 200, 240, 300, 400 мм)и 1мешок клея массой 25 кг.

Цена указана за 1 поддон! Скидки!

Наша компания является официальным партнером завода СИБИТ. Вы можете забрать продукцию напрямую на заводе, либо мы сделаем Вам доставку до места. Цены на доставку газобетона (сибита) по районам г. Новосибирска и в Бердск.

Варианты доставки сибита:

1-2 поддона: Газель, самогруз

1-15 поддонов: самогруз

35 поддонов: длинномер, самогрузы

Звоните! Скидки обсуждаются! Понедельник-пятница с 8-00 до 17-00: (383) 351-37-02, 354-84-99.

Понедельник-воскресенье с 7-00 до 22-00:913-987-46-58, 913-908-03-26 (МТС), 952-934-85-94 (Теле2). WhatsApp

Технические особенности автоклавного газобетона

Сибит используется как материал для кладки наружных и внутренних стен и перегородок сооружений не выше 5 этажей и расположенных в климатической зоне, где влажность воздуха не превышает 75%.

Там, где влажность выше 75% допускается строительство из газобетонных блоков в случае нанесения специального пароизоляционного покрытия на внутренние поверхности.При строительстве от 5-го до 9-го этажа можно использовать блоки сибита в самонесущих стенах дома.

Здания, построенные из сибита, имеют отличные противопожарные характеристики. Конструкция выдержит не менее 4-х часов открытого огня без потерь теплоизолирующей и несущей способности а также целостности.

Прекрасные звукоизолирующие свойства – одна из главных особенностей блоков из газобетона. Например, для стены толщиной 100 мм это 36 дБ, для стены толщиной 150 мм — 55 дБ. Такое возможно благодаря пористой структуре газобетона.

Газобетонные блоки СИБИТ можно использовать для возведения зданий в любых районах России. Для районов Крайнего Севера необходимо обеспечение сибита по морозостойкости не менее F35. Автоклавный газобетон может выдержать сто циклов оттаивания и замораживания.

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

На что класть первый ряд?

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

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

Справка

Рекомендуется использовать для кладки начального ряда блоков стандартную пропорцию цемента и пропущенного через сито песка в соотношении 1:3, с добавлением воды до получения смеси относительно густой консистенции.

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

Достоинства и свойства изделий из сибита

Все преимущества данного материала основаны на технических характеристиках блоков сибит. Их скоординированное сочетание самым лучшим образом отвечает требованиям, предъявляемым изделиям конструкционного и конструктивно-теплоизоляционного назначения. Для наглядности объединим основные свойства сибита и сравним их с традиционным кирпичом.

Наименование показателяЕд. изм.СибитКирпичПримечания

Масса конструкции

кг/м²

300

1200

Блок сибита объемом 0,036м³ весит 18 кг, а такой же объем кирпичей (15-20 шт) – до 80 кг.

Толщина стены (для климатических условий Сибири)

мм

600

1300

Плотность

кг/м³

400-700

1800

Коэф. теплопроводности

Вт/м*К

0,16

0,61

Морозостойкость

цикл

200

35

Паропроницаемость блоков из сибита в 5-6 раз выше, в сравнении с кирпичом, и равна 0,17 г/м. Это значит, что газобетон способен за короткое время избавиться от попавшей в него влаги и обеспечить в помещении нормальный

ширина | htmlbook.ru

Internet Explorer Хром Opera Safari Firefox Android iOS
6.0+ 8.0+ 1.0+ 3.5+ 3.1+ 1.0+ 1.0+ 1.0+

Краткая информация

Версии CSS

КСС 1 CSS 2 CSS 2.1 CSS 3

Описание

Устанавливает ширину блочных или заменяемых элементов (к ним, например, относится тег ). Ширина не включает толщину границ вокруг элемента, значение отступов и полей.

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

Табл. 1. Ширина действия в браузерах
Internet Explorer Opera 10+, Firefox, Chrome, Safari Опера 9
Не указан (режим совместимости) Если размер заданной ширины, то блок изменяет свои размеры, подстраиваясь под содержимое. В случае другой ширины равна значению ширины. Во всех случаях браузер работает по спецификации CSS.А именно, ширина блока получается сложением значений ширины, отступов, полей и границ.

Содержимое блока, если не помещается в заданные размеры, отображается поверх блока.

Ширина равна значению ширины.

Содержимое блока, если не помещается в заданные размеры, отображается поверх.

Переходный HTML
Строгий HTML
Ширина формируется путем сложения значений ширины, заполнения, поля и границы.

Содержимое блока, если не помещается в заданные размеры, отображается поверх.

Ширина равно значению ширина плюс отступ, поле и граница.

Содержимое блока, если не помещается в заданные размеры, отображается поверх.

HTML 5

XHTML

Синтаксис

ширина: значение | проценты | авто | унаследовать

Значения

В качестве значений принимаются любые длины, принятые в CSS — например, пикселы (px), дюйммы (in), области (pt) и др. При использовании процентной записи ширина элемента вычисляется в зависимости от ширины родительского элемента. Если явно указан не указан, то в его качестве выступает окно.

авто
Устанавливает ширину исходя из типа и содержимого элемент.
наследовать
Наследует значение родителя.

Пример

HTML5CSS2.1IECrOpSaFx

  

 
  
   ширина 
  <стиль>
   .layer1 {
    ширина: 300 пикселей; / * Ширина блока * /
    фон: # fc0; / * Цвет фона * /
    отступ: 7 пикселей; / * Поля вокруг текста * /
    граница: 1px solid #ccc; / * Параметры рамки * /
   }
   .layer2 {
    ширина: 400 пикселей; / * Ширина текстового блока * /
   }
  
 
 
  

Lorem ipsum dolor sit amet, consctetuer adipiscing elit, seddiem nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat.

.

Параметры css ширина и высота для задания размеров элементов html страницы: WEBCodius

Здравствуйте, уважаемые читатели! Сегодня мы рассмотрим как задавать размеры блочных элементов веб страницы с помощью css свойств и настроить контент в случае, если он помещается в элементенте.

width и height - ширина и высота элементов в css

С помощью атрибутов стиля ширину и высоту можно задавать соответственно ширину и высоту блочных элементов:

width: auto | <ширина> | наследовать
height: auto | <ширина> | наследовать

В качестве значений можно использовать любые доступные в css единицы измерения - например, пикселы (px), дюйммы (in), точки (pt) и др.:

p {width: 200px; height: 150px}

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

div {width: 40%;}

Значение auto отдает управление размерами элемента веб-браузеру и является значением по умолчанию. В этом случае размеры элемента будут такие, чтобы в нем полностью поместилось все его содержимое.

Рассмотрим несколько примеров.





width и height




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




Результат:

В этом примере мы создали блок div и вложили в него абзац с текстом. Для div-а мы строго задали размеры 300 на 300 пикселей. У элемента p значения ширина и высота равны автоматически, поэтому как видно на скриншоте, его ширина установилась равной ширине родительского элемента, а высота стала такая, чтобы в нем поместился весь текст в абзаце.

Теперь изменим css настройки для абзаца p и зададим фиксированные размеры:

.layer2 {
фон: #eee;
ширина: 250 пикселей;
}

Результат:

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

Теперь давайте зададим высоту и ширину абзаца в процентах:

.layer2 {
фон: #eee;
ширина: 50%;
высота: 50%;
}

Результат:

Как видно на картинке, ширина элемента стала равной ширины элемента div.А высота увеличилась и стала равна 75 процентам высоты дел.

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

Определить минимальную ширину и высоту можно с помощью атрибутов min-width и min-heigh:

min-width: <ширина>
min-height: <высота>

Аналогичные атрибуты стиля max-width и max-height позволяют задать максимальные размеры:

max-width: <ширина>
max-height: <высота>

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

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

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

Например, уменьшим размеры абзаца p из рассмотренных примеров до 100 пикселей:

.layer2 {
фон: #eee;
ширина: 100 пикселей;
высота: 100 пикселей;
}

Результат:

Как видно, текст вышел за границы абзаца и выглядит это не очень красиво.Для избежания подобного действия правило css - overflow.

Параметр переполнения переполнения для скрытия (скрыто, видно) или прокрутки (прокрутки, авто) контента

Переполнение контента может быть ограничено, когда ограничивают и ширину и высоту элемента. Рассмотрим два абзаца:

Текст первого абзаца


Текст второго абзаца

Результат:

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

Теперь у первого абзаца ограничим ширину:

Текст первого абзаца


Текст второго абзаца

Результат:

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

Ну а теперь ограничим у первого абзаца и высоту:

Текст первого абзаца


Текст второго абзаца

В результате получилось, что текст в такой ограниченный абзац не влазит и поэтому он наехал на область нижнего соседа.Соответственно прочитать текст ни в первом ни во втором абзацах практически не возможно. Именно для управления поведением контента в таких ситуациях существует правило переполнения :

переполнение: видимый | скрытый | прокрутка | авто | наследование

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

Правило overflow: hidden скрывает все, что не помещается в контейнере:

Значение scroll отображается в элементе по вертикали и горизонтали полосы прокрутки даже в том случае, если все содержимое умещается:

Текст первого абзаца


Текст второго абзаца

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

Текст первого абзаца


Текст второго абзаца

Результат:

Для настройки полос прокрутки можно также использовать атрибуты стиля overflow-x и overflow-y, которые позволяют настраивать отображение прокрутки по осям. Таким образом overflow-x отвечает за горизонтальную ось , а overflow-y за вертикальную ось .

Поэтому если вам, например, нужно, чтобы в абзаце горизонтальная прокрутка не появлялась никогда, а вертикальная появлялась только по необходимости, достаточно написать следующее правило css:

p {overflow-x: hidden; overflow-y: auto;}

И задача будет решена.

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

.

ширина - Веб-технологии для разработчиков

ширина Chrome Полная поддержка 1 Край Полная поддержка 12 Firefox Полная поддержка 1 IE Полная поддержка 4 Опера Полная поддержка 3.5 Safari Полная поддержка 1 WebView Android Полная поддержка 1 Chrome Android Полная поддержка 18 Firefox Android Полная поддержка 4 Опера Android Полная поддержка 10.1 Safari iOS Полная поддержка 1 Samsung Интернет Android Полная поддержка 1.0
Анимированные Хром Полная поддержка 26 Край Полная поддержка 12 Firefox Полная поддержка 16 IE Полная поддержка 11 Опера Полная поддержка 15 Safari Полная поддержка 6.1 WebView Android Полная поддержка 4.4 Chrome Android Полная поддержка 26 Firefox Android Полная поддержка 16 Опера Android Полная поддержка 14 Safari iOS Полная поддержка 6.1 Samsung Интернет Android Полная поддержка 1.5
заливка Экспериментальная Нестандартная Хром Полная поддержка 46 Край Полная поддержка 79 Firefox Нет поддержки Нет IE Нет поддержки Нет Opera Полная поддержка 33 Safari Полная поддержка 12 WebView Android Полная поддержка 46 Chrome Android Полная поддержка 46 Firefox Android Нет поддержки Нет Opera Android Полная поддержка 33 Safari iOS Полная поддержка 12 Samsung Интернет Android Полная поддержка 5.0
fit-content Хром Полная поддержка 46
Полная поддержка 46
Полная поддержка 22
С префиксом Требует вендорный префикс: -webkit-
Нет поддержки 1-48 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
Edge Полная поддержка 79
Полная поддержка 79
Полная поддержка 79
С префиксом Требует вендорный префикс: -webkit-
Firefox Полная поддержка 3
Полная поддержка 3
С префиксом Требует вендорный префикс: -moz-
IE Нет поддержки Нет Opera Полная поддержка 33
Полная поддержка 33
Полная поддержка 15
С префиксом Требует вендорный префикс: -webkit-
Нет поддержки 15-35 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
Safari Полная поддержка 11
Полная поддержка 11
Полная поддержка 6.1
С префиксом Требует вендорный префикс: -webkit-
Полная поддержка 2 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
WebView Android Полная поддержка 46
Полная поддержка 46
Полная поддержка ≤37
С префиксом Требует вендорный префикс: -webkit-
Нет поддержки 1-48 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
Chrome Android Полная поддержка 46
Полная поддержка 46
Полная поддержка 25
С префиксом Требует вендорный префикс: -webkit-
Нет поддержки 18 - 48 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
Firefox Android Полная поддержка 4
Полная поддержка 4
С префиксом Требует вендорный префикс: -moz-
Opera Android Полная поддержка 33
Полная поддержка 33
Полная поддержка 14
С префиксом Требует вендорный префикс: -webkit-
Нет поддержки 14 - 35 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
Safari iOS Полная поддержка 11
Полная поддержка 11
Полная поддержка 7
С префиксом Требует вендорный префикс: -webkit-
Полная поддержка 1 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
Samsung Internet Android Полная поддержка 5.0
Полная поддержка 5,0
Полная поддержка 1.5
С префиксом Требует вендорный префикс: -webkit-
Нет поддержки 1.0 - 5.0 Альтернативное имя
Альтернативное имя Используется нестандартное имя: intrinsic
max-content Chrome Полная поддержка 46
Полная поддержка 46
Полная поддержка 22
С префиксом Требует вендорный префикс: -webkit-
Edge Полная поддержка 79
Полная поддержка 79
Полная поддержка 79
С префиксом Требует вендорный префикс: -webkit-
Firefox Полная поддержка 66
Полная поддержка 66
Полная поддержка 3
С префиксом Требует вендорный префикс: -moz-
IE Нет поддержки Нет Opera Полная поддержка 44 Safari Полная поддержка 11
Полная поддержка 11
Полная поддержка 2 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
WebView Android Полная поддержка 46 Chrome Android Полная поддержка 46 Firefox Android Полная поддержка 66
Полная поддержка 66
Полная поддержка 4
С префиксом Требует вендорный префикс: -moz-
Opera Android Полная поддержка 43 Safari iOS Полная поддержка 11
Полная поддержка 11
Полная поддержка 1 Альтернативное имя
Альтернативное имя Используется нестандартное имя: внутреннее
Samsung Internet Android Полная поддержка 5.0
мин-содержание Хром Полная поддержка 46
Полная поддержка 46
Нет поддержки 1-48 Альтернативное имя
Альтернативное имя Используется нестандартное имя: min-intrinsic
Edge Полная поддержка 79 Firefox Полная поддержка 66
Полная поддержка 66
Полная поддержка 3
С префиксом Требует вендорный префикс: -moz-
IE Нет поддержки Нет Opera Полная поддержка 33
Полная поддержка 33
Нет поддержки 15-35 Альтернативное имя
Альтернативное имя Используется нестандартное имя: min-intrinsic
Safari Полная поддержка 11
Полная поддержка 11
Полная поддержка 2 Альтернативное имя
Альтернативное имя Используется нестандартное имя: min-intrinsic
WebView Android Полная поддержка 46
Полная поддержка 46
Нет поддержки 1-48 Альтернативное имя
Альтернативное имя Используется нестандартное имя: min-intrinsic
Chrome Android Полная поддержка 46
Полная поддержка 46
Нет поддержки 18 - 48 Альтернативное имя
Альтернативное имя Используется нестандартное имя: min-intrinsic
Firefox Android Полная поддержка 66
Полная поддержка 66
Полная поддержка 4
С префиксом Требует вендорный префикс: -moz-
Opera Android Полная поддержка 33
Полная поддержка 33
Нет поддержки 14-35 Альтернативное имя
Альтернативное имя Используется нестандартное имя: min-intrinsic
Safari iOS Полная поддержка 11
Полная поддержка 11
Полная поддержка 1 Альтернативное имя
Альтернативное имя Используется нестандартное имя: min-intrinsic
Samsung Internet Android Полная поддержка 5.0
Полная поддержка 5,0
Нет поддержки 1.0 - 5.0 Альтернативное имя
Альтернативное имя Использует нестандартное имя: min-intrinsic
stretch Экспериментальная Chrome Полная поддержка 22 Альтернативное имя
Полная поддержка 22 Альтернативное имя
Альтернативное имя Используется нестандартное имя: -webkit-fill-available
Edge Полная поддержка 79 Альтернативное имя
Полная поддержка 79 Альтернативное имя
.

Как задается в css размер блока: свойства ширина, высота, отступ

Как задавать в css размер блока

От автора: здравствуйте, читатели этого блога. В этой статье я хочу поделиться с вами информацией по тому, как определять в css размер блока, то есть элемента на веб-странице.

На какие типы делятся элементы

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

Блочные элементы имеют абсолютно другое поведение. Без дополнительных манипуляций они не могут стать в один ряд. Пример блока - абзац, который задается тегом p. Так вот, зачем я вам все это говорю? Это сказано для того, чтобы вы понимали - размер нужно задавать только блочным элементом, что мы и будем делать в этой статье.

Рис.1. Основные свойства, которые определяют размер

Практический курс по верстке адаптивного сайта с нуля!

Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3

Узнать подробнее

Простые свойства для размеров

Самые простые размеры, которые можно записать - это width и height. Означают они, соответственно, ширину и высоту. К ним также можно дописывать префиксы min- и max-. В таком случае будет задаваться минимальная и максимальная ширина или высота соответственно.

Значения можно записывать в пикселях или в процентах. Иногда еще используется относительная единица em (высота шрифта), но обычно с ее помощью определяется величина текста. По умолчанию все сетки (главные структурные блоки шаблона), определяющие размеры в процентах, называют резиновыми. Также процентная запись помогает легко адаптировать шаблон, что тоже очень важно.

в пикселях

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

#контейнер{ ширина: 1000 пикселей; }

#container {

width: 1000px;

}

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

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

И все же умение сетки сайта адаптироваться под новые экраны имеет сегодня огромную роль. В связи с этим последние годы все чаще главный контейнер для каркаса сайта получает не жесткую ширину.Например, так:

#контейнер{ максимальная ширина: 1320 пикселей; }

#container {

max-width: 1320px;

}

И что это значит? А то, что при необходимости блок будет уменьшаться. Если сжать окно, то он тоже уменьшится. В то же время, если разрешение экрана позволяет, ширина будет составлять 1320 пикселей ровно. Уменьшая окно вы не видите горизонтальный скролл.

Однако тут же можно задать еще и минимальную ширину.Если блоку записать это свойство, то он не будет становиться уже, чем указанное значение. Например:

#контейнер{ минимальная ширина: 600 пикселей; }

#container {

min-width: 600px;

}

Практический курс по верстке адаптивного сайта с нуля!

Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3

Узнать подробнее

Если ширина окна станет меньше 600 пикселей, то блок перестанет сжиматься и появиться та самая горизонтальная полоса прокрутки.

в процентах

Задавать в процентах Размер становится все более популярным. При грамотном использовании это может принести отличное отображение сайта на разных устройствах.

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

#sidebar { плыть налево; ширина: 28%; } #content { float: right; ширина: 62%; }

#sidebar {

float: left;

ширина: 28%;

}

#content {

float: right;

ширина: 62%;

}

В итоге сайдбар получит 28% ширины родительского элемента (а в нашем этом общем контейнере), основной блок - 62%.Их общая ширина составит 90%. Остальные 10 оставим на различные внешние и внутренние отступы, рамки и т.д.

Рис. 2. Резиновые блоки изменяют свои размеры при уменьшении окна в браузере

Влияние отступы на размеры блоков

Когда вы задаете ширину какому-то блоку с помощью свойств ширины, это может быть далеко не окончательное значение. Дело в том, что так мы определяем ширину той части, в которой непосредственно есть содержимое.Нужно помнить, что в css padding увеличивает размер блока, так же, как и рамка (граница).

Допустим, возьмем боковую колонку. Мы дали ей 28% от всей ширины контейнера. Но чтобы содержимое в сайдбаре не прилипало к краям, ем нужно дать кое-какие отступы. Также, возможно, вы захотите добавить боковую колонку рамочку.

#sidebar { отступ: 10 пикселей 20 пикселей; граница: сплошной черный цвет 2px; }

#sidebar {

padding: 10px 20px;

граница: сплошной черный 2 пикселя;

}

Вот уже и получается, что общая ширина сайдбара увеличилась на 44 пикселя (отступ справа и слева по 20 и рамка с этих же сторон по 2).Есть вариант для тех, кто не хочет сильно заморачиваться над размерами и записывать их сразу с учетом отступов и рамок. Тогда нужно записать так:

* { размер коробки: рамка-рамка; }

* {

размер коробки: рамка рамки;

}

Это замечательное свойство делает так, что в ширину блока (ширину) начинают включаться внутренние отступы (отступы) и рамки. Теперь если вы зададите контенту размер в 62%, он останется таковым в любом случае.А ведь есть еще и внешние отступы, но они уже на размеры блока не влияет. Если вы хотите сделать, допустим, большой отступ справа от боковой колонки, то контент просто не влезет и вынужден будет перенестись вниз.

Резиновые картинки

Чтобы дать возможность в css картинке меняться по размеру блока, ей нужно задавать ширину в процентах. Таким образом, если сам блок имеет относительный размер или прописан max-width, то при уменьшении ширины картинка и блок будут уменьшаться синхронно, что есть хорошо для хорошего отображения сайта.

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

Итог

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

Практический курс по верстке адаптивного сайта с нуля!

Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3

Узнать подробнее

PSD в HTML

Верстка сайта на HTML5 и CSS3 с нуля

Смотреть.

LEAVE A REPLY

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