Верстка блоками div давно уже стала стандартом и имеет ряд преимуществ перед табличной версткой. Однако на деле начинающие разработчики путаются в поведении этих самых блоков.
Давайте разберем основные моменты при блочной верстке. Сейчас мы не будем брать во внимание стандарт html5, а просто рассмотрим основу основ при верстке блоками div, которая используется при создании макета или же какого то отдельного компонента страницы.
Область такого элемента на странице представлена прямоугольником, по умолчанию занимает все доступную ширину и начинается с новой строки.
Самым распространённым элементом, используемым в блочной верстке, является универсальный элемент
Итак, от простого к сложному. Посмотрим, как отобразятся блоки div по умолчанию без стилей, влияющих на их положение. Для наглядности стили к элементам будем добавлять инлайново, через атрибут style.
Добавим значение ширины для каждого блока:
Видно, что каждый блок согласно спецификации располагается с новой строки. Это их нормальное поведение.
Теперь возникает вопрос, как расположить блоки div на одной строке , друг за другом?
Для этого существует свойство , которое определяет, с какой стороны блок будет принудительно выровнен. При этом с другого края, он может обтекаться другими элементами.
Свойство float имеет следующие значения:
Добавим float:left к нашим блокам, чтобы блоки выровнялись по левому краю:
В результате, блоки выстроились на одной строке. Хорошо, допустим, мы захотели добавить еще один div снизу, и сделаем это без указания свойства float:
Блок 1. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 2. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 3. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 4. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Блок 1. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 2. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 3. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 4. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Почему так вышло? Вкратце, так происходит, потому что элементы с float выпадают из потока документа. Однако, это тема отдельной статьи. Здесь же мы познакомимся с новым свойством , которое управляет поведением плавающих элементов:
Добавим Блоку 4 свойство clear:left, которое запретит этому элементу обтекание других плавающих элементов с левой стороны.
Блок 1. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 2. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 3. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 4. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Блок 4 разместился с новой строки, как нам надо.
В данном случае мы знаем как располагаются другие блоки, потому в примере сразу указали clear:left. Бывают ситуации, когда мы точно не знаем, с какой стороны встретится плавающий блок, поэтому в таких случаях стоит указывать clear:both, отменяющий обтекание с обеих сторон. Теперь мы разобрались как расположить блоки div на одной строке горизонтально.
Следует помнить, что блоки со значением float располагаются на одной строке, если позволяет ширина родительского элемента. Если блочные элементы не умещаются в ряд, они будут переноситься на новую строку. Если это критично, например, при верстке макетов, нужно это учитывать и у блоков с float обязательно задавать ширину - фиксированную (px) или резиновую (%, rem и т.д.). Дальше посмотрим на такие ситуации.
Как повлиять на блоки, если мы хотим разместить эти блоки по центру?
Классическим решением будет добавление блокам родителя и использование свойства margin: 0 auto;
Почему собственно родителю мы дали класс.wrapper ? «wrapper» в переводе означает «обертка». Это некая общепризнанная практика, определяющая название класса, когда элемент оборачивает другие блоки и тем самым позволяет управлять/влиять на них посредством изменения самого родителя.
Возьмем разметку из предыдущих примеров и усовершенствуем её.
Блок 1. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 2. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 3. Lorem ipsum dolor sit amet, consectetur adipisicing elit
Блок 4. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Здесь вроде всё просто.
А если нам не нравится, что текст вплотную прилипает к краю родительского блока и хотим добавить поля без внесения изменений в разметку, только с помощью css. Добавим элементам свойство padding:
Блок 1. Lorem
Блок 2. Lorem ipsum
Блок 3. Lorem ipsum
Блок 4. Lorem
И видим, что наша верстка рассыпалась! Блок 3 куда то уехал. Почему так вышло? Ответ прост. Добавив поля элементам мы увеличили их ширину. Теперь значения таковы:
Блок 1: 10 + 200 + 10 = 220px
Блок 2: 10 + 150 + 10 = 170px
Блок 3: 10 + 100 + 10 = 120px
Блок 4: 10 + 450 + 10 = 470px
220 + 170 + 120 = 510px
Общая ширина трех блоков 510, они не умещаются в ширину родителя (450) и потому переносятся на новую строку.
Как поправить? Можно сделать следующее:
Используем второй вариант, получается так:
Блок 1. Lorem
Блок 2. Lorem ipsum
Блок 3. Lorem ipsum
Блок 4. Lorem
Теперь соберём всю полученную информацию воедино и попробуем создать простенький типовой трёхколоночный макет с резиновой версткой, который будет растягиваться максимально до 900px, после чего весь макет будет позиционироваться по центру.
Создаем разметку макета:
Пишем стили:
Body { max-width: 900px; /* ограничение максимальной ширины */ margin: 0 auto; } /* для всех блоков внутри body изменяем алгоритм расчета ширины блоков и добавляем все блокам поля 10px */ body div { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; padding: 10px; } .header { background: #CCA69E; padding: 10px; } .left-sidebar { width: 20%; background: #8ED9B6; float: left; } .content { float: left; width: 60%; } .right-sidebar { width: 20%; background: #FF9282; float: left; } .footer { background: #000; clear: both; /* запрещаем обтекание с обоих сторон, блок выводится с новой строки */ color: #ccc; }
Если что-то непонятно — спрашивайте в комментариях.
Элемент
Как и при использовании других блочных элементов, содержимое тега
Обязателен.
Пример 1. Использование тега
HTML: | 3.2 | 4 | XHTML: | 1.0 | 1.1 |
Выравнивание содержимого контейнера
Пример 2. Выравнивание текста
HTML: | 3.2 | 4 | XHTML: | 1.0 | 1.1 |
Добавляет поясняющий текст к контейнеру
Любая текстовая строка. Строка должна заключаться в двойные или одинарные кавычки.
Пример 3. Подсказка к тексту
Добрый день друзья! Как то в своих нескольких уроках по html я говорил и употреблял такое понятие как div верстка.
У вас наверняка возникли вопросы, особенно если вы новички, что же это такое?
В сегодняшней статье я развею все ваши сомнения и отвечу на вопросы что из себя представляют div блоки в
Приступим к изучению.
Чтобы не захламлять и замусоривать ваш мозг, вкратце лишь скажу, что раньше все веб дизайнеры и разработчики при создании страниц и сайтов использовали табличную верстку, где каждая ячейка представляла из себя определенный элемент. Примерно это выглядело вот так:
Вот примерно таким было создание сайтов. Это очень примитивный пример, зато вы наглядно можете представить как создавались сайты в те далекие времена. Технологии интернет не стоят на месте и в какой-то момент к нам пришло такое понятие как html div верстка. И тут, как говорится, понеслось.
Ее значение в сайтостроении действительно велико. Теперь создавать сайты и управлять блоками html стало проще простого. Сайты стали получаться красивыми, интересными. Теперь весь мир верстает ими только в путь.
Вот так теперь можно изобразить упрощенно модель использования div html блоков.
Удобство заключается в независимости блоков друг от друга, ими легко управлять по отдельности, двигать как вам угодно, добавлять стили, можно задавать общие стили через CSS правила для нескольких групп Div. Согласитесь это удобно.
Давайте разберем на практике несколько примеров как можно применить теги div на html странице. На простом примере мы создадим 4 блока на странице. Я буду всегда использовать в этом и дальнейших примерах программу Notepad++
Итак, давайте поясню. У нас есть конструкция < ! DOCTYPE html > она годна для современных браузеров и поддерживает разметку html 5 про нее мы поговорим в дальнейших выпусках.
Далее открывается большой «родительский» контейнер < html > . Он парный его нужно закрыть в конце обязательно! Потом идет открытие служебного тега < head > , который тоже парный и в нем содержится служебная информация о кодировке < meta charset > , самый главный seo заголовок страницы title, описание (его сюда я не включал, ибо нет необходимости, мы разбираем чисто технический аспект), сюда же подключают CSS стили, шрифты (библиотека Google Fonts), яваскрипты.
Следующим идет тег < body > . В нем уже будет хранится вся наша разметка блоков и все контейнеры с тегами. Просто запомните его как огромную «бочку».
И вот, наконец, пошли наши контейнеры div.
< div class = "header" > < / div > < div class = "sidebar" > < / div > < div class = "content" > < / div > < div class = "footer" > < / div > |
Важно! Они тоже парные их нужно также наряду с другими тегами закрывать.
Каждый блок див как видите имеет атрибут class, после знака равенства вы можете самостоятельно и произвольно задавать их. Эти классы созданы специально для CSS. Т.е браузер заходит на страницу, видит блок div и смотрит, какая информация в нем содержится и идет в CSS файл и уже там ищет нужный класс.
Можно задавать не только атрибут class, но также можно использовать и id (идентификатор). Вы можете задать вопрос: «А какая мне разница, какой использовать?» Отвечу, для верстки можете применить любой способ. С одним лишь отличием — по приоритету id имеет больше привилегий, чем class .
Это я поясню в видео шпаргалке ниже.
У каждого свой стиль создания сайтов, мне больше нравится использовать именно class, поскольку эта запись в CSS отображается с точкой . selector
Да, кстати, хочу сказать, что header, sidebar, content, footer — это все селекторы CSS, а они уже будут иметь атрибуты.
Итак, продолжаем разгребать кашу в головах пользователей. Div блоки с class мы создали теперь приступим к CSS.
Откроем внутри тега head css правила для нашей страницы, т.е оформим ее. Сделаем это вот так:
Запись будет следующей (просто скопируйте и вставьте в своем примере и посмотрите в браузере)
< ! DOCTYPE HTML > < html > < head > < meta charset = "utf-8" > < title > Примериспользованияdiv тегов< / title >
< / head > |
Еще каких-то десять лет назад в рунете наиболее часто использовалась так называемая табличная верстка. Ввиду того что стандарты некоторых браузеров значительно отличались друг от друга, приходилось искать решение, которое бы позволило правильно отобразить интернет-документ во всех приложениях. Но время шло, развивались стандарты, и на смену достаточно жесткой и негибкой табличной пришла хорошо изменяемая и отзывчивая Во главе угла такой технологии лежит принцип использования элементов
Усложнение веб-страниц и развитие компьютерной техники привело к тому, что веб-документ был разделен на две части — каркас (HTML-код) и оформление (таблицы стилей). Благодаря этому удалось достичь небывалого развития веба, результаты которого мы сейчас можем лицезреть на большинстве современных сайтов. Кроме улучшения процесса разработки
Тег
Теги
Для того чтобы создать действительно правильный документ, необходимо использовать следующую структуру тега
Блок
Естественно, блочная структура документа вовсе не подразумевает использование только лишь одних тегов
Как уже было сказано выше, данный тег не изменяет оформление фрагмента страницы, а используется для создания семантической структуры с последующим оформлением посредством таблиц стилей. Использование закрывающего тега для этого элемента является обязательным.
Несмотря на то что многие современные браузеры смогут распознать такую ошибку, в некоторых случаях незакрытый тег может стать причиной «разваливания» структуры документа и его неверного отображения.
Так как данный элемент является блочным, то вмещенный в него контент будет начинаться с новой строки. Для изменения подобного поведения необходимо изменить параметры отображения блока свойством display. Кроме группирования вложенных элементов, тег
Использование атрибута position позволяет изменить метод позиционирования выбранного элемента. Так, существует три типа позиционирования:
Для изменения позиции относительно точки начала координат используются атрибуты top и left. Значения могут быть как положительными, так и отрицательными. Ширина и высота блочного элемента задается атрибутами width и height соответственно. Если они не были указаны в таблицах стилей, то блок будет занимать всю ширину родительского элемента. Если контент блока не помещается по всей ширине «родителя», то тогда поведение элемента определяется атрибутом overflow.
Надеемся, данная стать помогла разобраться с вопросом о том, что такое
ДИВ ДИВ
дива, в восточнославянской мифологии персонаж. Упомянут в средневековых «Словах»-поучениях против язычества (в форме «дива») и дважды в «Слове о полку Игореве»: приурочен к верху дерева («Дивъ кличетъ връху древа») и спускается вниз («уже връжеся дивъ на землю»). Демон и женский мифологический персонаж со сходным именем известен у западных славян (чеш. divy muž, diva žena, польск. dzivožona; сербо-лужицк. dziwja žona, dŸiwica, обычно связываемые с лесом), а также у южных славян (болг. самодива, синонимичное самовиле, см. Вилы
). Слово первоначально было связано, с одной стороны, с русским «диво» и родственными славянскими обозначениями чуда, с другой стороны - со славянскими и балтийскими словами в значении «дикий», происходящими из «божий»: ср.
укр. дивий - «дикий», старослав. «дивии», болг. «див», польск. dziwy, «дикий» при латыш. dieva zuosis, «дикий гусь» - первоначально в значении «гусь бога»; ср. также родственное хеттское šiu - «бог» в šiunaš huitar, «животные богов», т. е. «дикие звери»; и типологические кетские параллели - Esdδ Sel, «дикий олень», т. е. «олень бога Эся». Развитие в славянском отрицательных значений типа «дикий» иногда связывают с влиянием иранской мифологии, в которой родственное слово из общеиндоевропейского значения «бог» (см. также Дый
) превратилось в обозначение отрицательного мифологического персонажа - дэва (см. Дэвы
). В значении «бог» у иранцев выступило переосмысленное обозначение доли (др.-инд. bhaga): ср. слав. Бог;
оба эти взаимосвязанных процесса объединяют славянские и иранские языки и мифологии. След древнего индоевропейского значения «бог ясного неба» (см. Индоевропейская мифология
) можно видеть в мотиве падения Д. на землю, имеющем соответствия в древнеиранском (patat dyaoš, «сверзился с неба») и древнегреческом (διοπετής,«сверженный с неба»; ср. также хеттский миф о боге луны, упавшем с неба, и т. п.).
Лит.:
Иванов В. В.. Топоров В. Н„ К проблеме достоверности поздних вторичных источников в связи с исследованиями в области мифологии, в кн.: Труды по знаковым системам, т. в, Тарту, 1973.
В. В. Иванов, В. Н. Топоров.
(Источник: «Мифы народов мира».)
ДИВнебо, отец богов и людей, правитель Вселенной и создатель молний (тождествен Святовиту и Сварогу). Старинные русские памятники говорят о поклонении богу Диву, и если в этом свидетельстве вероятнее видеть указание на светлое небесное божество, то все-таки не может быть сомнения, что уже в отдаленной древности со словом «дивы» связывалось понятие о драконах и великанах туч. «Слово о полку Игореве» упоминает о диве, восседающем на дереве, подобно Соловью-разбойнику и мифическим змеям. Со словом «диво» однозначительно чудо, встречаемое в старинных рукописях в значении исполина, гиганта; Морское чудо (Морской Царь), владыка дожденосных туч, точно также как Лесное чудо - леший, обитатель облачных лесов.
(Источник: «Славянская мифология. Словарь-справочник.»)
див - див/ … Морфемно-орфографический словарь
Див: Дивы Д.И.В. Часть имени или топонима Публий Лициний Красс Див Сен Пьер сюр Див (кантон) Бретвиль сюр Див Див сюр Мер Сен Пьер сюр Див Марк Лициний Красс Див (сын триумвира) См. также Div WWE Поиск Див … Википедия
Главный калибр Корпорации Тяжелого Рока. История этой трэш группы началась в первой половине 80 х в СПТУ 39, где волею судеб оказались вместе Виктор Алкаш Лемков и Сергей Лысый Тайдаков. Объединив усилия, они попробовали играть хард рок, но армия … Русский рок. Малая энциклопедия
А; м. Нар. поэт. Сказочное существо невиданно чудного или страшного вида. * * * ДИВ ДИВ, в восточнославянской мифологии один из духов дикой природы … Энциклопедический словарь
А, муж. Стар. редк.Отч.: Дивович, Дивовна.Производные: Дива.Происхождение: (От лат. divus божественный.) Словарь личных имён. Див а, м. Стар. редк. Отч.: Дивович, Дивовна. Производные: Дива. [От лат. divus божественный.] Словарь русских личных… … Словарь личных имен
див - 1 іменник чоловічого роду, істота у міфології див 2 іменник чоловічого роду диво рідко … Орфографічний словник української мови
ДиВ - «Движение и воздух» омская научно производственная фирма г. Омск, образование и наука Источник: http://www.regnum.ru/expnews/170584.html ДИВ Джугашвили Иосиф Виссарионович истор., СССР … Словарь сокращений и аббревиатур
В восточнославянской мифологии один из духов дикой природы … Большой Энциклопедический словарь
М. Сказочное существо; чудище, чудовище (в восточной мифологии). Толковый словарь Ефремовой. Т. Ф. Ефремова. 2000 … Современный толковый словарь русского языка Ефремовой
- (перс, div гений, санскр. div небо, лат. divinus божественный). 1) злой дух. 2) пугач филин, сова, ночн. ворон; зловещая птица. Словарь иностранных слов, вошедших в состав русского языка. Чудинов А.Н., 1910 … Словарь иностранных слов русского языка