Блочные и строчные теги. Основы html


В HTML большинство элементов можно разделить на две группы: блочные (blok ) и строчные (inline ).

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

Строчные элементы

К строчным элементам относятся теги: ,
, , , , , , , ....

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

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

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

Блочные элементы

К блочным элементам относятся теги:

,
,

...

,
,
    ,

    ,

    ,
      ....

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

      Один или несколько блоков также могут располагаться внутри другого (родительского ) блочного элемента.

      В CSS блоки создаются на основе элементов HTML и имеют следующую структуру.

      Любой блок имеет форму прямоугольника.

      Блочный элемент имеет границу и содержимое: это может быть текстовая информация, фотографии, логотип фирмы и т.п., называемое контентом (англ. content - содержание ).

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

      Между содержимым и границей существуют внутренние расстояния - поля (свойство padding ). Ими необязательно пользоваться. То есть если их явно не установить при помощи свойства padding , то граница будет вплотную примыкать к содержимому блока, либо отстоять от него на каком-то минимальном расстоянии. С другой стороны, поля могут иметь совершенно конкретные размеры, которые указывает разработчик.

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

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

      Фрагмент кода:

      Строчные элементы расположены на одной строке. Они заключены в блочный элемент - абзац! Перенос текста происходит автоматически - в конце строки.

      Следующий блок - абзац, начинается с новой строки.


      Два абзаца расположены.


      Внутри блока - тега div !


      Отдельные фрагменты текста заключены в тег span. И для них задано стилевое оформление!

      Результат:

      Строчные элементы расположены на одной строке. Они заключены в блочный элемент - абзац! Перенос текста происходит автоматически - в конце строки.

      Следующий блок - абзац, начинается с новой строки.

      Два абзаца расположены.

      Внутри блока - тега div !

      Отдельные фрагменты текста заключены в тег span. И для них задано стилевое оформление!

      Блочные элементы занимают всю ширину своего родителя (контейнера), формально создавая «блок» (отсюда и название).

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

      Блочные элементы

      HTML

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

      CSS

      p { background-color: #8ABB55; }

      Использование

      • Блочные элементы могут отображаться только внутри элемента и его потомков.

      Блочные против строчных

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

      Содержание Как правило, блочные элементы могут содержать строчные элементы и другие блочные элементы. Неотъемлемой частью этого структурного различия является идея, что блочные элементы создают «более крупную» структуру , чем встроенные элементы . Форматирование по умолчанию По умолчанию блочные элементы начинаются с новой строки, а строчные могут начинаться в любом месте строки.

      Разделение элементов на блочные и строчные использовалось в спецификации HTML до версии 4.01 . В HTML5 это противопоставление заменено более сложным набором категорий контента . Категория «строчных » элементов примерно соответствует категории , а для «блочных» элементов прямого соответствия нет, но «блочные» и «строчные» элементы вместе примерно соответствуют категории потокового контента в HTML5 (т.е., грубо говоря, «блочные» элементы - это потоковый контент минус текстовый контент). Кроме того, есть и другие категории, например, интерактивный контент.

      Элементы

      Ниже приведен полный список всех блочных элементов (хотя формально понятие «блочный » не применяется к новым элементам в HTML5 ) .

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

      HTML5 Содержание статьи. представляет собой раздел документа с контентом, косвенно связанным с основным содержимым документа (часто представленным как боковая панель)."> HTML5 Побочное содержание. (от англ. Block Quotation) указывает на то, что заключенный в нем текст является развернутой цитатой. Обычно он (текст) визуально выделяется наклонным (смотри Примечание, где говорится о том, как это изменить). URI на источник цитаты можно указать в атрибуте cite, тогда как текстовое представление источника может быть задано элементом .">
      Длинная («блочная») цитата. используется для раскрытия скрытой (дополнительной) информации.">
      HTML5 Раскрывающийся блок с подробностями. определяет диалоговое окно или другой интерактивный элемент, такой как инспектор или окно. Элементы
      могут интегрироваться с диалогом с помощью указания атрибута method=" dialog returnvalue value submit.> HTML5 Диалоговое окно.
      Описание определения. ) является базовым контейнером для элементов основного потока (flow content). Он не влияет на контент или формат пока не стилизован, используя CSS. Являясь "> по своему существу не представляет ничего. Между тем, он используется для группировки контента, что позволяет легко его стилизовать, используя ">
      Фрагмент документа. (от англ. Description List), служащий контейнером для списка пар терминов и их описаний. Этот элемент обычно используют при создании глоссария или для отображения метаданных (списка пар ключ-значение).">
      Список определений.
      Термин в списке определений.
      Группирование элементов формы.
      HTML5 Описание для тега
      ), и обычно используется как единое целое.">
      . представляет самостоятельный контент, часто с подписью (
      ), и обычно используется как единое целое.">
      HTML5 Группирование медиа-контента с подписью (см.
      ). представляет нижний колонтитул (футер, подвал) для своего ближайшего элемента секционного контента или секционного корня. Футер обычно содержит информацию об авторе секции, информацию об авторском праве или ссылки на связанные документы.">
      HTML5 Нижняя часть ( «подвал ») раздела или страницы . ) представляет (собой) раздел документа, содержащий интерактивные элементы управления, которые позволяют пользователю отправлять информацию на веб-сервер."> Форма ввода.

      ,

      ,

      ,

      ,

      ,
      Заголовки от первого до шестого уровня. HTML5 Верхняя часть ( «шапка ») раздела или страницы.

      В первой статье про html я приводил список тэгов, которые, по моему мнению нужно знать верстальщику. Остальные тэги, по сути, являются избыточными или даже лишними, по моему мнению. В этой статье я хотел бы рассказать об основах html и о тэгах html, head, title, body, а так же о div и span. Эти теги, по моему мнению - хорошая основа для начала изучения html.

      К сожалению, современные браузеры очень лояльно относятся к веб-верстальщикам. Они пытаются интерпретировать все, что им скармливают. Незакрытые тэги, тэги в разных регистрах, непонятные тэги, теги, стоящие там, где их быть не должно и т.д. Например, лично видел сайт, где контейнер head располагался внутри body, а тег title был даже вне контейнера head. При этом, внешне сайт выглядел нормально!

      Я очень надеюсь, что когда-нибудь стандарты станут жесткими, и неправильно сверстанные страницы не будут отображаться верно. Правда, для этого нужно, чтобы все браузеры обрабатывали html и CSS одинаково… Ну да меня занесло.

      Как обычно в таких случаях, сначала накидаем план занятия:

      1. Общие правила
      2. Структура документа

      Общие правила

      Для начала, стоит сказать, что html — довольно лояльный язык. Существует версия html, стандарт которой ужесточен, — xhtml. Я стараюсь придерживаться этого стандарта. В частности, этот стандарт предполагает, что все теги написаны в нижнем регистре и закрыты. Даже одиночные. Как — будет показано ниже. Все атрибуты написаны в нижнем регистре, а их значения заключены в двойные кавычки и имеют обозначение величины, в которой измеряется их значение. Будем придерживаться этих правил.

      Стандартами предусмотрено определенное расположение некоторых элементов. Если элемент, который должен располагаться где-то, располагается в другом месте — это считается ошибкой. Вообще-то, такой документ не должен обрабатываться или должен обрабатываться с ошибкой. Но браузеры щадят нерадивых разработчиков. Точнее, своих пользователей, которые смотрят сайты, разработанные нерадивыми разработчиками.

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

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

      Пример контейнера (парные теги):


      содержимое контейнера

      Пример одиночного тега

      текст одной строки
      этот текст уже на другой строке

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

      Блочные и внутристрочные теги

      Различие между блочными и внутристрочными (inline) тегами состоит в том, что блочный элемент стремится занять весь экран по ширине (если не явно не указана его ширина) , а внутристрочный занимает ровно столько места, сколько занимает его содержимое. Кроме того, все, что следует за блочным элементом, будет отображаться с новой строки, а то, что за внутристрочным — прямо за ним. Контейнер div является по-умолчанию, блочным, а тег span - внутристрочным. (правда, это поведение легко изменить при помощи CSS). Проиллюстрируем поведение этих тегов.


      Текст1. Этот текст занимает всю ширину страницы.


      Этот текст идет уже ПОД первым текстом и весь тоже занимает всю страницу
      целиком. Но красненький текст, заключенный
      в тег span, не переносит следующий за ним текст на новую строку и занимает
      ровно столько места, сколько нужно.

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

      Неправильно:

      текст

      Правильно:
      текст

      Есть еще одна вещь, о которой хочу сказать: у тегов могут быть атрибуты. Атрибут задает определенное поведение или как-то дополняет тег. Атрибут пишется прямо в теге, через пробел от его названия, в формате: ИМЯ_АТРИБУТА="ЗНАЧЕНИЕ[мера]". ИМЯ_АТРИБУТА и ЗНАЧЕНИЕ, думаю, понятно что такое. А мера — это обозначение единиц измерения. Если единицы измерения нет, то и выдумывать ее не надо.

      Пример применения атрибута

      Здесь мы задаем атрибут высоты для контейнера div (вообще-то, это лучше делать при помощи CSS, но в данном случае, я написал это, чтобы показать как это вообще может выглядеть) . Атрибуты могут быть назначены только в открывающих тегах. Количество пробелов не имеет значения. Можно ставить пробелы между названием тега и атрибутом, между названием атрибута и знаком равенства, между знаком равенства и кавычкой. Можно ставить пробелы в кавычках, но только не между величиной и единицами ее измерения! Кавычки не обязательно должны быть двойными, можно применять "одинарные кавычки", но только в паре. Вариант "кавычки" не прокатит. В этом случае, одинарная кавычка, как и все, что следует после, будут интерпретированы как часть значения атрибута.

      Вроде, это все, что я хотел сказать, в общем. Так что, к делу!

      Структура документа

      То, что будет описано ниже, как раз относится к разряду обязательного к соблюдению. Так что не стоит думать, что если "и так отображается", то это нормально. Это НЕ нормально.

      Каждый документ должен быть заключен в теги Эти теги, как видно, парные. Так что не забывайте открывать такой тег в начале документа и закрывать в конце. По идее, все, что идет за закрвающим тегом уже не должно анализироваться брауезром. Но оно анализируется и даже отображается. Но не советую использовать это. Что примечательно, до открывающего тега может идти другое содержимое. Но в этой статье я не буду об этом говорить. Кто хочет, может поискать про DOCTYPE.

      Все остальное содержимое документа должно содержаться в контейнере html. Документ делится на две части. Одна несет управляющую функцию и дополнительную информацию для браузера. А другая — информацию для пользователя. Управляющая часть называется , а содержательная — . Причем контейнер head должен стоят всегда перед body. Эти два контейнера не должны включать друг друга.

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

      Таким образом, простейший html-документ выглядит примерно так:



      Название документа


      Здесь тело документа

      Можете скопировать этот текст в блокнот (или похожий текстовый редактор), сохранить этот файл с расширением.html и перетащить в окно своего браузера. Вы увидите, что текст, содержащийся в контейнере title, отобразился в заголовке страницы, а текст из body отобразился в пользовательской части.

      Закончим рассмотрение основных тегов документа и возьмемся за теги представления содержимого.

      Теги для логического разделения содержимого

      Для начала скажу, что теги, которые я рассмотрю ниже, могут находиться только в теге body.

      Этот контейнер предназначен для того, чтобы объединять некий текст в логический блок, отделенный от остального содержимого страницы. Если вы возьмете текст нашего простейшего документа и заключите текст из тела документа в этот контейнер, то никаких внешних изменений не заметите. Однако, они, все же, есть. Для текста, заключенного в контейнер div, можно задать одно стилевое оформление. Этот блок можно сделать определенной ширины, задать для него другой шрифт, сделать выравнивание по правому краю или что угодно еще. Вот пример использования тега div (для краткости, не буду приводить весь текст документа целиком. Но вы должны помнить, что нижестоящую конструкцию вы должны вставить в контейнер body для того, чтобы увидеть ее работу.):


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


      Основной текст страницы. Наверное, он не должен быть длинным, ведь это всего-лишь тест.

      Не стоит пугаться незнакомого атрибута style и непонятных слов в нем (таких ли уж непонятных?). Просто контейнер div лучше было показать вместе с этим атрибутом. Чаще всего, в правильной верстке, для контейнеров используются атрибуты id и class, которые служат для связи тега с CSS или идентификации его для JavaScript. Но это уже забегание вперед;)

      Контейнер div является блочным элементом. Но это поведение легко изменить.

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

      Итог

      В этой статье мы познакомились с общими правилами html, узнали о минимальной структуре документа html, о парных и непарных тегах, и о блочных и внутристрочных контейнерах. Мы увидели разницу между контейнерами разного типа, а так же, познакомились с логическими контейнерами div и span.

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

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

      ,
      ,
      ,
      , ,

      ,...,

      ,
      ,
        ,

        ,

        , 
    ,
      и некоторые устаревшие. Также блочным становится элемент, если в стиле для него свойство display задано как block , list-item , table и в некоторых случаях run-in .

      Для блочных элементов характерны следующие особенности.

      • Блоки располагаются по вертикали друг под другом.
      • На прилегающих сторонах элементов действует эффект схлопывания отступов.
      • Запрещено вставлять блочный элемент внутрь строчного. Например,

        Заголовок

        не пройдёт валидацию, правильно вложить теги наоборот -

        Заголовок

        .
      • По ширине блочные элементы занимают всё допустимое пространство.
      • Если задана ширина контента (свойство width ), то ширина блока складывается из значений width , полей, границ, отступов слева и справа.
      • Высота блочного элемента вычисляется браузером автоматически, исходя из содержимого блока.
      • Если задана высота контента (свойство height ), то высота блока складывается из значения height , полей, границ, отступов сверху и снизу. При превышении указанной высоты контент отображается поверх блока.
      • На блочные элементы не действуют свойства, предназначенные для строчных элементов, вроде vertical-align .
      • Текст по умолчанию выравнивается по левому краю.

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

      как универсальный кирпичик вёрстки. Тег
      допустимо вкладывать один в другой, другие блочные элементы также можно помещать внутрь
      . В примере 3.13 показан фрагмент кода сайта CSS Zen Garden , где активно применяются эти теги для формирования требуемой конструкции.

      Пример 3.13. Использование тега

      A demonstration of what can be accomplished visually through CSS - based design. Select any style sheet from the list to load it into this page.

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

      располагается два тега

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

      Пример 3.14. Анонимный блок

      Анонимный блок

      Первый абзац

      Анонимный блок

      Второй абзац

      Схематично блоки в данном примере показаны на рис. 3.23. Серым цветом выделены блочные теги

      А пунктиром - анонимный блок.

      Рис. 3.23. Блоки в документе

      Преобразование в блочный элемент

      В некоторых случаях требуется наделить строчный элемент характеристиками блочного. Так, превращение ссылки в блок позволяет увеличить полезную площадь ссылки за счёт использования свойств width и height . В примере 3.15 показано создание меню, в котором ссылками является вся доступная область.

      Пример 3.15. Меню

      XHTML 1.0 CSS 2.1 IE Cr Op Sa Fx

      Меню

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

      Влад Мержевич

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

      ,

      ,

      И др.

      Допускается вкладывать один блочный элемент внутрь другого, а также размещать внутри них встроенные элементы (, например). Запрещено добавлять внутрь встроенных элементов блочные (пример 1).

      Пример 1. Использование блочных элементов

      Блочные элементы

      Lorem ipsum dolor sit amet...

      Ut wisi enim ad minim veniam

      В данном примере абзац (тег

      ) вставляется внутрь контейнера

      , а ссылка (тег ) — в заголовок

      . Кстати, ошибкой будет поступить наоборот — добавить

      в контейнер (

      Ut wisi

      ), поскольку тег
      не относится к блочным элементам.

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

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

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

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

      Некоторые браузеры достаточно свободно трактуют понятие ширины, хотя в спецификации CSS четко указано, что ширина складывается из суммы следующих параметров: ширины самого блока (width ), отступов (margin ), полей (padding ) и границ (border ). В примере 2 показано создание слоя, в котором присутствуют все эти компоненты.

      Пример 2. Ширина слоя

      Ширина

      Lorem ipsum dolor sit amet...

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

      Рис 1. Ширина блочного элемента

      В том случае когда в коде не указан, браузер Internet Explorer за ширину всего блока принимает значение свойства width .

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

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

      Пример 3. Ширина слоя в процентах

      Ширина

      Lorem ipsum dolor sit amet...

      Lorem ipsum dolor sit amet...

      Lorem ipsum dolor sit amet...

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

      Рис. 2. Отображение ширины слоев в браузере

      Ширина первого слоя в данном примере (layer1 ) установлена как 100%, что приводит к отображению горизонтальной полосы прокрутки. Для второго слоя (layer2 ) ширина также задана 100%, но поля определяются для внутреннего абзаца (тег

      ). За счет этого ширина слоя во всех браузерах будет одинаковой. К третьему слою (layer3 ) вообще не применяется свойство width , поэтому оно определяется по умолчанию — auto . В таком случае слой будет занимать всю ширину окна браузера без всяких горизонтальных полос.

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

      Высота

      С высотой блочных элементов дело обстоит аналогично ширине. Браузер за высоту слоя принимает значение свойства height и добавляет к нему еще значение margin , padding и border . Если высота слоя не установлена явно, то она вычисляется автоматически исходя из объема содержимого.

      Допустим, для слоя установлена высота в пикселах, а содержимое слоя однозначно превышает указанную высоту (пример 4).

      Пример 4. Высота слоя

      Высота

      Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis te feugifacilisi.

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

      Рис. 3. Высота блока в разных браузерах

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

      Цвет фона

      Цвет фона элемента проще всего устанавливать через универсальное свойство background . Фоном при этом заливается область, которая определяется значениями width , height и padding (рис. 4).

      Рис. 4. Область слоя, которая заполняется фоновым цветом

      Таким образом, margin не принимает участия в формировании цветной области.

      Границы

      Из-за разницы в подходах браузеров при формировании блочных элементов наблюдается и различие при отображении границ. Браузер Internet Explorer 7 проводит рамку внутри блока, а Firefox — снаружи. Но если использовать фоновую заливку, то увидим совершенно противоположную картину (рис. 5). А все потому, что Firefox (Opera) цвет фона устанавливает по внешнему краю границы, а Internet Explorer — по внутренней. Начиная с версии 8.0 Internet Explorer поменял стиль отображения рамки, она проводится внутри блока, как и в Firefox.

      а. Internet Explorer 7

      б. Firefox, Internet Explorer 8+

      Рис. 5. Отображение рамки в браузерах

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

      Пример 5. Пунктирная рамка

      Рамка

      Lorem ipsum dolor sit amet...

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

      Резюме

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

      Спецификация CSS определяет, что высота и ширина элемента определяется не только значениями height и width , но к ним еще плюсуется значение полей, отступов и границ. Браузеры в этом плане делятся на две части: одни поддерживают в этом вопросе спецификацию, другие же ее игнорируют и поступают по-своему. Это создает трудности разработчикам, которые желают делать универсальные веб-страницы. Можно только посоветовать ограниченно использовать свойства width и height , поскольку по умолчанию браузер применяет аргумент auto , который заставляет настраивать размеры элемента автоматически.