Тег | htmlbook.ru
Internet Explorer | Chrome | Opera | Safari | Firefox | Android | iOS |
4.0+ | 1.0+ | 4.0+ | 1.0+ | 1.0+ | 1.0+ | 1.0+ |
Спецификация
HTML: | 3.2 | 4.01 | 5.0 | XHTML: | 1.0 | 1.1 |
Описание
Элемент <div> является блочным элементом и предназначен для выделения фрагмента документа с целью изменения вида содержимого. Как правило, вид блока управляется с помощью стилей. Чтобы не описывать каждый раз стиль внутри тега, можно выделить стиль во внешнюю таблицу стилей, а для тега добавить атрибут class или id с именем селектора.
Как и при использовании других блочных элементов, содержимое тега <div> всегда начинается с новой строки. После него также добавляется перенос строки.
Синтаксис
<div>...</div>
Атрибуты
- align
- Задает выравнивание содержимого тега <div>.
- title
- Добавляет всплывающую подсказку к содержимому.
Также для этого тега доступны универсальные атрибуты и события.
Закрывающий тег
Обязателен.
Пример
HTML5IECrOpSaFx
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title>Тег DIV</title> <style type="text/css"> .block1 { width: 200px; background: #ccc; padding: 5px; padding-right: 20px; border: solid 1px black; float: left; } .block2 { width: 200px; background: #fc0; padding: 5px; border: solid 1px black; float: left; position: relative; top: 40px; left: -70px; } </style> </head> <body> <div>Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat.</div> <div>Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.</div> </body> </html>
Результат данного примера показан на рис. 1.
Рис. 1. Вид блоков, оформленных с помощью стилей
Как создать таблицу только с помощью тега и Css
Это старая тема, но я подумал, что должен опубликовать свое решение. Недавно я столкнулся с той же проблемой, и способ ее решения заключается в том, чтобы следовать трехэтапному подходу , описанному ниже, который очень прост без каких-либо сложных CSS .
(NOTE : конечно, для современных браузеров использование значений атрибута table или table-row или table-cell для отображения CSS решило бы проблему. Но подход, который я использовал, будет одинаково хорошо работать в современных и старых браузерах, так как он не использует эти значения для атрибута display CSS.)
3-ШАГОВЫЙ ПРОСТОЙ ПОДХОД
Для таблицы с divs только так, чтобы вы получили ячейки и строки, как и в элементе таблицы, используйте следующий подход.
- Замените элемент таблицы блоком div (используйте класс
.table
) - Замените каждый из TR или-й элемент с блока div (использовать класс
.row
) - Замените каждый элемент td встроенным блоком div (используйте класс
.cell
)
.table {display:block; }
.row { display:block;}
.cell {display:inline-block;}
<h3>Table below using table element</h3> <table cellspacing="0" > <tr> <td>Mike</td> <td>36 years</td> <td>Architect</td> </tr> <tr> <td>Sunil</td> <td>45 years</td> <td>Vice President aas</td> </tr> <tr> <td>Jason</td> <td>27 years</td> <td>Junior Developer</td> </tr> </table> <h3>Table below is using Divs only</h3> <div> <div> <div> Mike </div> <div> 36 years </div> <div> Architect </div> </div> <div> <div> Sunil </div> <div> 45 years </div> <div> Vice President </div> </div> <div> <div> Jason </div> <div> 27 years </div> <div> Junior Developer </div> </div> </div>
UPDATE 1
Чтобы обойти эффект одинаковой ширины, не поддерживаемый во всех ячейках столбца, как это было упомянуто thatslch
в комментарии, можно было бы принять любой из двух приведенных ниже подходов.
Укажите ширину для класса
cell
ячейка {display:inline-block; width:340px;}
Используйте CSS современных браузеров, как показано ниже.
.table {display:table; } .row { display:table-row;} .cell {display:table-cell;}
Таблица моделирования CSS Hell с DIV
http://jsfiddle.net/nluis3294/uLuof882/
Я думаю, мы все согласны с тем, что вы должны использовать таблицы для табличных данных и divs для не табличных данных. В идеальном мире, я думаю, что все будет делать.
однако также можно сказать, что я хочу, чтобы мои не табличные данные были выровнены в сетке и что эти строки и столбцы должны растягиваться как обычная таблица html. Это дизайнерский выбор, и он абсолютно законный. Вот в чем трудности. Вы можете использовать таблицы, которые намного проще, но технически неверны. Или вы можете использовать divs и полагаться на такие трюки, как фоновые изображения, искусственные столбцы и прокладки, чтобы заставить его выглядеть как таблицы.
используя искусственные столбцы тоже не кажутся мне «правильными». Если вы хотите изменить ширину столбца, нужно изменить фоновое изображение. И использование фонового изображения для установки цвета фона кажется мне странным. У меня есть аналогичные оговорки о других трюках, таких как столбцы Psuedo или трюки с отрицательными полями. В моем oppinion они должны просто изменить css, чтобы позволить простой способ получить что-то, что выглядит как сетка без трюков.
<div> <div> <div> aa </div> <div> bb<br/> bbb2 </div> <div> cc<br/> cccc2 </div> <div> dddddd<br/> dddddd </div> </div> <div> <div> aa </div> <div> bb<br/> bbb2 </div> <div> cc<br/> cccc2 </div> <div> dddddd<br/> dddddd </div> </div> <div> <div> aaa aaa </div> <div> bb<br/> bbb2<br/> bbbbbbbbbbbbbbbbbbbb3 </div> <div> cccccc<br/> </div> <div> ddddd<br/> ddd </div> </div> </div>
CSS:
div.testTable{ width: 30%; display: table; table-layout: auto; padding:0; margin:0; } div.testRow{ display: table-row; width: 100%; white-space: nowrap; vertical-align:top; padding:0; margin:0; } div.testColumn1{ display: table-cell; height:100%; min-width: 25%; background-color: #CCD9FF; vertical-align:top; padding: 0.2em; border: 1px solid black; margin:0; } div.testColumn2{ display: table-cell; height:100%; min-width: 25%;background-color: #ECFFE5; vertical-align:top; padding: 0.2em; border: 1px solid black; margin:0; } div.testColumn3{ display: table-cell; height:100%; min-width: 25%;background-color: #FFEBE5; vertical-align:top; padding: 0.2em; border: 1px solid black; margin:0; } div.testColumn4{ display: table-cell; height:100%; min-width: 25%;background-color: #FFFFCC; vertical-align:top; padding: 0.2em; border: 1px solid black; margin:0; }
Дивы,таблицы, как надо и как не надо
Давно лежит в черновиках у меня статейка про прелести и ужасы обоих подходов в верстке. Когда то, давным-давно, никто даже и не загонялся по поводу каких-то дивов, верстали таблицами и все было гуд. Я сам так делал.
Вроде все просто, посмотрел на дизайн, накинул мысленно сетку таблицы, разрезал, разверстал. Проблема возникала, когда требовалось разверстать сложный диз, там таблица а в ней еще таблица а в ней еще таблица и т.д. Вобщем, ужас.
С дивами вроде проще — можно и стиль прописать без излишнего кода и понятно будет для чего этот див. Но иногда их очень трудно отпозиционировать относительно друг друга. Сейчас уже мне в дивах намного проще сверстать.
Итак, таблицы.
Табличная верстка очень сильно увеличивает размер документа и иногда вообще не возможно понять, кому и какой элемент принадлежит. Также таблицы снижают способность сайта к масштабированию, уменьшая общую функциональность.
MAMA (Metadata Analysis and Mining Application, приложение для анализа и разработки метаданных) это структурированный вебпоисковик от Opera Software, занимается парсингом страниц и возвращает их детализированую структуры.
По данным МАМЫ, большинство сайтов юзает таблицы, да еще и таблицы по три уровня вложенности. Среди самых популярных тегов: table, td и tr присутствуют само собой. 80% сайтов, которые знает МАМА, состоят из таблиц. Такая вот статистика.
С точки зрения семантики — таблица — это элемент для представления табличных данных, он не оптимизирован для построения структуры.
Простота использования.
В таблицах проще представить практически любой дизайн. Таблица это сетка, и она без труда накладывается на любое изображение, представляя почти готовый макет для разверстки.
Обслуживаемость.
Таблица состоит из тучи тегов: table открывает таблицу, tr открывает ряды, td открывает ячейки. Есть еще thead и tbody, они добавляют свои строки в заголовок и в тело таблицы, их можно не использовать.
Для читабельности, каждому тегу отдают свою строку. Rowspan и colspan вытягивают одну ячейку по колонке/столбцу, добавляя еще болей непонятности в код.
Вот такая вот конструкция + дополнительные теги (img и тп) + сам контент добавляется в тело документа. Разобратся в структуре бывает весьма непросто.
табличный вариант
<table border="0" cellspacing="0" cellpadding="0"> <tbody> <tr> <td colspan="3">....</td> </tr> <tr> <td valign="top">...</td> <td valign="top">...</td> <td valign="top">...</td> </tr> <tr> <td colspan="3">...</td> </tr> </tbody></table>
вариант для дивов
<div>...</div> <div>...</div> <div>...</div> <div>...</div> <div>...</div>
Как видно, в таблице кода будет побольше. Нетрудно представить, как может разростись код при увеличении страницы.
В дивах div id=menu еще можно заменить на неупорядоченный список ul. Таблицы также далеки от чистого кода, и в идеале должны использоватся для отображения табличных данных.
Все это слегка намекает, что code smell(код попахивает, домен кстати двухзнак в ком!).
Еще в таблицах тяжелее отпозиционировать контент. МАМА сообщает, что среди сайтов юзающих таблицы, 90% используют border, width, cellpadding и cellspacing. Все это дело обычно не выносят в цсс, что добавляет еще кода.
А как известно, цсс то кешируется в браузере, а вот хтмл документ нет.
Для особо кропотливых — программер пишет строк кода больше, но кпд этого кода ниже, следовательно он тратит рабочее время на пустоту.
Есть еще другая статистика — это отношение ошибок на строку кода. Чем больше строк кода, тем больше ошибок. Вот так.
Гибкость при использовании.
В идеале, очень удобно использовать одну и ту же страницу и для компов и для принтеров и для мобильных. С таблицами так не получится, нужно будет делать отдельные страницы, заточенные под каждый конкретный вид.
Доки по теме таблиц
Сайтеги на таблицах
Дивы.
Див (div), блочный элемент, который определяет секцию внутри документа.
Дивы хорошо подходят для создания структуры страницы. В случае необходимости, можно без проблем вложить/заключить див в другой элемент.
Простота использования
Блочная верстка подразумевает наличие более продвинутых знаний у разработчика нежели табличная. Требуется знание CSS и понятие чем отличаются блочные и встроеные элементы, когда использовать плавающее или абсолютное позиционирование, и как пофиксить глюки некоторых, абсолютно всеми любимых браузеров от мелкософта.
Див выглядит иначе таблицы. Все представляют, как выглядит таблица, а вот с дивом напряг. Див это одиночный блок, он не ограничивается каким-то родительским элементом, как td например.
Основная беда блочной верстки — это предугадать, как поведут себя элементы, если например контент начнет вылазить за пределы элемента. Может посыпатся абсолютно все. Или уехать в сторону. Новые браузеры более обтекаемо позиционируют контент в таких случаях, однако есть один всеми любимый браузер, вот в нем бывают чудеса.
Работа с фиксами под браузеры поначалу тяжковата, но все приходит с опытом. Поддержка стандартов W3C сейчас реализована у всех браузеров в какой-то мере. Поскольку браузеров становится больше, конкуренция растет, стандарты ессно стараются все реализовать быстрее чем конкуренты.
Обслуживаемость
Проблема дивов в том, что их пихают везде где только можно. В идеале дивы должны использоваться только для представления структуры и для закрепления элементов там, где по другому их крепить нельзя. Или для логического группирования элементов.
Вкладывавание дивов друг в друга — это путь к большому гемору. Тронув такой код, можно всю верстку порушить.
Идеал — группировать одним дивом элементы, описывая их свойсвта в родительском класса.
В группах неплохо бы описывать структуру другими не блочными элементами для улучшения понимания кода.
<div> <h2>heading</h2> <p>text</p> </div>
воспринимается проще чем
<div></div> <div></div> <div></div>
Пишите понятней.
Еще парочка причина, зачем делать семантическую верстку:
- Боты поисковиков индексируют сайты. Делая верстку более понятной и упрощенной, возможно повысит ваш сайт в выдаче.
- Некоторые юзеры используют навигацию по странице при помощи клавиатуры (ноуты) или используют всякие девайсы для для серфинга. Правильная разметка даст правильную навигацию.
Гибкость при использовании
Даже при переусердствовании дивами сайт может быть легко отображен где угодно, если дизайн отделен от контента и вынесен в стили. Есть полезная статья “Going to Print” в которой расказывается как сделать сайт максимально полезным для принтера.
Чрезмерная структура также мешает некоторым браузерам от Мозиллы корректно печатать документы.
Почитать по теме:
Сайты с переизбытком дивов:
Так как же надо?
Как говорится в пословице, сдуру можно и ухо сломать. При неумелом подходе можно испортить оба метода верстки.
Используем дивы правильно
Перед созданием нового дива, нужно прикинуть, а нужен ли он тут или нет. h2-5 вполне могут заменить заголовки, а списками можно сделать и меню и сами списки и вертикальные блоки до кучи. Еще есть параграф p.
Для гибкости вывода форм, можно заключать их в fieldset, а его уже в список.
Не забывайте, что чем меньше дивов, тем меньше кода, тем он проще, тем меньше в нем ошибок.Когда контент разверстан, переходим к картинкам. Для начала их пробуют вставить в документ при помощи background-image и других средств CSS. Если этого никак не сделать, то можно создать новый див.
Всякие штучки
Несколько базовых приемов. Приводятся с целью обращения верстальщиков в идеи чучхе в правильную верстку. Обратите внимание на читабельность кода.
меню
<ul> <li><a href="#">Home</a></li> <li><a href="#">Products</a></li> <li><a href="#">About</a></li> </ul>
Меню как список очень просто в использовании. Тег li блочный, может иметь бекграунд. Такие меню занимают мало места, в них просто встроить подменю.
заголовки
<h2>Main heading</h2> <h3>Normal heading</h3>
Используйте заголовки где можно. Они дают некоторый вес в ПС + облегчают восприятие документа.
списки
<ul> <li> <img /> <h3 /> <p /> <a /> </li> <li> <img /> <h3 /> <p /> <a /> </li> </ul>
Группируйте схожие куски кода и добавляйте их в код. Списки хорошие контейнеры. В списках не нарушается чередование элементов. Т.е. дивы могут разьехатся и последний может стать первым, списки даже если и поползут, очередность элементов останется.
контейнеры различной ширины
<body class=»newsShow»>
<div id=»content»></div>
<div id=»aSide»></div>
</body>
/* Containers */
#content { float: left; }
#aSide { float: right; }
/* Page structures */
.newsShow #content { width: 80%; }
.newsShow #aSide { width: 20%; }
.home #content { width: 70%; }
.home #aSide { width: 30%; }
.oneColumn #content { width: 100%; }
С классом для body нет нужды делать разную ширину для блоков. Просто обратитесь к контейнеру через body и управляйте шириной через CSS, поменяв ему стиль на другой.
данные для отправки в списке
<dl>
<dt>Your name is:</dt>
<dd>Susan Hanson</dd>
<dt>Your address is:</dt>
<dd>Street name 1</dd>
<dt>You live in:</dt>
<dd>Oslo</dd>
</dl>
DL используется, когда значения в списке парные. Многие используют таблицы, но dl предпочтительней. Также он выставляет ширину для dd и dt, создает семантический порядок между этими элементами. dd и dt блочные элементы.
простая форма
<form>
<ul>
<li>
<fieldset>
<legend>Person info</legend>
<ul>
<li>
<label for=»name»>Name:</label>
<input type=»text» name=»name» id=»name» />
</li>
<li>
<label for=»age»>Age:</label>
<input type=»text» name=»age» id=»age» />
</li>
…
</ul>
</fieldset>
</li>
<li>
<fieldset>
<legend>Address info</legend>
<ul>
<li>
<label for=»address»>Address:</label>
<input type=»text» name=»address» id=»address» />
</li>
<li>
<label for=»zip»>Zip:</label>
<input type=»text» name=»zip» id=»zip» />
</li>
…
</ul>
</fieldset>
</li>
…
</ul>
</form>
В этом примере показана семантически структурированная форма с контейнерами для вывода. Иметь хорошее отображение форм в документе иногда бывает очень трудно, для чего используют вложенные таблицы. fieldset обьеденяет форму в контейнер.
Вобщем, как не раз уже говорилось, дивы используйте для разметки структуры. Для всего остального используйте списки, параграфы и т.п.
Почитать:
Как перейти с таблиц на дивы
- Попробуйте убирать вложенные таблицы, заменяя подходящими тегами p span ul и т.д. Понемногу убирая таблицы, можно добится сокращения размеров документа.
- Не добавляйте новых таблиц не для табличных данных.
- Разделяйте дизайн и контент. Код для разметки вынесите в css.
- Проверьте, нельзя сделать код более чистым, более семантичным.
- Сделать новый код может выйти дороже по времени и средствам, чем потихоньку его усовершенствовать.
- Не пишите плохой код. Лучше сберегите свое время.
В будущем
Ждут нас две хорошие новости. Это HTML5 и CSS3. Первый будет содержать семантические теги и css-разметку а-ля таблицы, второй помима множества вкусностей типа круглых уголков при помощи CSS, будет фича под названием мультиколонная структура.
HTML5
С приходом HTML 5, мы сможем увидеть структурную разметку страницы, которая подчеркивает, что структура имеет значение.
Это добавит несколько возможностей для краулеров:
- Поисковики смогут более корректно оценить структурированный контент
- Упростится задача чтения с экрана людьми, имеющие проблемы со зрением и читающие при помощи спец устройств.
- Разметка для маленьких экранов станет более стандартизированной.
Вместе со структурными элементами, HTML 5 также представит новые теги. Несколько самых интересных:
video
иaudio
привнесут новую, семантически обоснованную разметку для контента и позволит видео и аудио потоки направлять напрямую в браузер.- Формы получат новую и улучшеную семантику для ввода текста и валидации форм.
- Новый тег
canvas
будет иметь API для двухмерной отрисовки.
HTML 5 будет также содержать много новых APIs, например:
- Немедленный режим отрисовки 2D
- Временное воспроизведение медиа
- Оффлайн хранилище
- Редактирование
- Drag and drop
- Messaging/networking
- Управление кнопкой “Back”
- Обработчик регистрации MIME и протоколов
Работа над HTML 5 началась в конце 2003 и имеет сроки:
- Первая W3C рабочая примерка в октябре 2007
- Последний созыв в октябре 2009
- Тестовый пакет для распространителей в 2011
- Подготовка релиз-кандидата в 2012
- Первая проба текстового пакета в 2012
- Вторая проба тестового пакета в 2015
- Финальная версия тестового пакета в 2019
- Последний сбор рабочей команды в 2020
- Предложенные рекомендации в 2022
19 лет для разработки это конечно круто, но как и в случае с HTML 4, DOM2 HTML и XHTML1, три спецификации HTML 5 предполагается заменить. До 2022 года разрабы не хотят выпускать в пользование, потому что спецификации и требования могут поменятся.
Табличный вывод средствами CSS
Нововведение, позволяет отображать блочные элементы как таблицы про помощи CSS. Аттрибут display
как заголовок table
, и атрибут display
для блочных элементов, которые отображаются как колонки , будут выведены как table-cell
. Табличный вывод на CSS будет более надежным, чем плавающий режим, колонки будут автоматом подгонятся по ширине.
<body>
<ul id=»menu»>
<li><a href=»#»>Home</a></li>
<li><a href=»#»>Products</a></li>
<li><a href=»#»>About</a></li>
</ul>
<div id=»content»>
<p>Fusce quis velit…</p>
</div>
<div id=»aSide»>
<p>Praesent iaculis commodo elit…</p>
</div>
</body>
body { display: table; table-layout: fixed;}
#menu, #content, #aSide { display: table-cell; }
#menu { width: 20%; border: 2px solid red;}
#content { width: 50%; border: 2px solid blue; }
#aSide { width: 29%; border: 2px solid green;}
Разделитель (в примере — body
) выставлен отображатся как table
, относящиеся колонки выставлены как table-cell
. Это также работает для элементов списка.
Мультиколоночный вывод при помощи CSS
Немного уличной магии CSS3 поможет отпозиционировать текст в колонки без элементов. Это делается при помощи выставления либо ширины либо количества колонок.
Мультиколоночный вывод уже поддерживается в Mozilla и в Webkit-based браузерах, элементы в стилях имеют префиксы -moz-
и -webkit-.
Ширина колонок
Число колонок зависит от того, какая ширина выставлена (промежуток между колонками регулирует свойство column-gap
) и насколько широк контейнер.
-webkit-column-width: 8em;
-webkit-column-gap: 1em;
-moz-column-width: 8em;
-moz-column-gap: 1em;
Число колонок
Свойство column-count
определяет, на сколько колонок будет делиться текст. Ширина зависит от ширины контейнера, размера растояний между колонками и границами колонок.
-webkit-column-count: 2;
-webkit-column-gap: 1em;
-webkit-column-rule: 1px solid black;
-moz-column-count: 2;
-moz-column-gap: 1em;
-moz-column-rule: 1px solid black;
На почитать:
Знание различий между блочными и внутренними элементами
Блочный элемент в HTML это тег (например p
, table
, h2
или div
) после котого идет обрыв. Блочные элементы имеют 5 свойств: height
, width
, margin
, border
и padding
. Внутренний элемент, например span или anchor, не делает после себя обрыв и не так гибок при использование его как контейнера как блочный элемент. Блочный элемент не допустим внутри внутреннего элемента.
Мой вольный перевод с дополнениями вот это статьи
4.80 avg. rating (93% score) — 5 votes
Верстка блоками DIV. С самого начала — html(5), css
Верстка блоками div давно уже стала стандартом и имеет ряд преимуществ перед табличной версткой. Однако на деле начинающие разработчики путаются в поведении этих самых блоков.
Давайте разберем основные моменты при блочной верстке. Сейчас мы не будем брать во внимание стандарт html5, а просто рассмотрим основу основ при верстке блоками div, которая используется при создании макета или же какого то отдельного компонента страницы.
Что считать блочным элементом?
Область такого элемента на странице представлена прямоугольником, по умолчанию занимает все доступную ширину и начинается с новой строки.
Самым распространённым элементом, используемым в блочной верстке, является универсальный элемент <div>.
Итак, от простого к сложному. Посмотрим, как отобразятся блоки div по умолчанию без стилей, влияющих на их положение. Для наглядности стили к элементам будем добавлять инлайново, через атрибут style.
<div>Блок 1</div>
<div> Блок 2</div>
<div> Блок 3</div>
Блок 1
Блок 2
Блок 3
Добавим значение ширины для каждого блока:
<div>Блок 1</div>
<div> Блок 2</div>
<div> Блок 3</div>
Блок 1
Блок 2
Блок 3
Видно, что каждый блок согласно спецификации располагается с новой строки. Это их нормальное поведение.
Теперь возникает вопрос, как расположить блоки div на одной строке, друг за другом?
Для этого существует свойство float, которое определяет, с какой стороны блок будет принудительно выровнен. При этом с другого края, он может обтекаться другими элементами.
Свойство float имеет следующие значения:
- left – блок выравнивается по левому краю, обтекание справа
- right – блок выравнивается по правому краю, обтекание слева
- none – обтекание не задано, блок ведет себя по умолчанию, как в предыдущих примерах.
Добавим float:left к нашим блокам, чтобы блоки выровнялись по левому краю:
<div>Блок 1</div>
<div> Блок 2</div>
<div> Блок 3</div>
Блок 1
Блок 2
Блок 3
В результате, блоки выстроились на одной строке. Хорошо, допустим, мы захотели добавить еще один div снизу, и сделаем это без указания свойства float:
<div>Блок 1. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div> Блок 2. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div> Блок 3. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div>Блок 4. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</div>
Блок 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. На самом деле, Блок 4 занимает место от начала Блока 1 и на 450 пикселов вправа. Вот посмотрите:
Блок 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 выпадают из потока документа. Однако, это тема отдельной статьи. Здесь же мы познакомимся с новым свойством clear, которое управляет поведением плавающих элементов:
- left – запрещает обтекание с левой стороны, все элементы будут показаны с новой строки (под элементом)
- rigth – запрещает обтекание элемента с правой стороны
- both – запрещает обтекание элемента с обоих сторон, рекомендуется использовать, когда явно надо показать элемент с новой строки или неизвестно с какой именно стороны возможно обтекание другими элементами
Добавим Блоку 4 свойство clear:left, которое запретит этому элементу обтекание других плавающих элементов с левой стороны.
<div>Блок 1. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div>Блок 2. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div>Блок 3. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div>Блок 4. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</div>
Блок 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» в переводе означает «обертка». Это некая общепризнанная практика, определяющая название класса, когда элемент оборачивает другие блоки и тем самым позволяет управлять/влиять на них посредством изменения самого родителя.
Возьмем разметку из предыдущих примеров и усовершенствуем её.
<div>
<div>Блок 1. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div>Блок 2. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div>Блок 3. Lorem ipsum dolor sit amet, consectetur adipisicing elit</div>
<div>Блок 4. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</div>
</div>
Блок 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) и потому переносятся на новую строку.
Как поправить? Можно сделать следующее:
- Задать заново значения ширины для каждого блока с учетом полей. Уменьшив размеры блоков. Все снова аккуратно встанет в одну строку. Согласитесь, это неудобно? Каждый раз лезть в верстку и что-то править.
- Использовать свойство box-sizing: border-box. Чтобы расчет брался из общей ширины блока. Советую узнать, что такое блоковая модель сss.
Используем второй вариант, получается так:
<div>
<div>Блок 1. Lorem</div>
<div>Блок 2. Lorem ipsum</div>
<div>Блок 3. Lorem ipsum</div>
<div>Блок 4. Lorem</div>
</div>
Блок 1. Lorem
Блок 2. Lorem ipsum
Блок 3. Lorem ipsum
Блок 4. Lorem
Теперь соберём всю полученную информацию воедино и попробуем создать простенький типовой трёхколоночный макет с резиновой версткой, который будет растягиваться максимально до 900px, после чего весь макет будет позиционироваться по центру.
Создаем разметку макета:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div> Шапка сайта </div> <div> Lorem ipsum dolor sit amet, consectetur adipisicing elit. In itaque dolor vitae praesentium consectetur molestias consequatur voluptatem rem dolore nihil officiis voluptates aperiam asperiores, saepe iure repudiandae expedita natus eaque magnam tempore delectus. </div> <div> Lorem ipsum dolor sit amet, consectetur adipisicing elit. Odit rem fugit itaque, est impedit aperiam a autem repellat vitae porro ex expedita, cumque nulla, velit. Soluta velit eos, quia. Fugiat voluptates nisi aliquid eum sapiente sunt nobis, adipisci assumenda earum! </div> <div> Lorem ipsum dolor sit amet, consectetur adipisicing elit. In itaque dolor vitae praesentium consectetur molestias consequatur voluptatem rem dolore nihil officiis voluptates aperiam asperiores, saepe iure repudiandae expedita natus eaque magnam tempore delectus. </div> <div> Подвал </div> </body> </html>
Пишем стили:
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; }
Посмотреть пример.
Если что-то непонятно — спрашивайте в комментариях.
СSS Таблицы
Внешний вид таблицы HTML может быть значительно улучшена с помощью CSS:
Компания | Контакты | Страна |
---|---|---|
Alfreds Futterkiste | Мария Андерс | Германия |
Berglunds snabbköp | Кристина Берглунд | Швеция |
Centro comercial Moctezuma | Франсиско Чанг | Мексика |
Ernst Handel | Роланд Мендель | Австрия |
Island Trading | Хелен Беннетт | Великобритания |
Königlich Essen | Филипп Крамер | Германия |
Laughing Bacchus Winecellars | Йоши Таннфмури | Канада |
Magazzini Alimentari Riuniti | Иоанн Ровелли | Италия |
Границы таблицы
Чтобы задать границы таблицы в CSS, используйте свойство border
.
Пример ниже определяет черными границами для элемнтов <table>
, <th>
, и <td>
:
Обратите внимание, что таблица в примере выше имеет двойную границу.
Это потому, что обе таблицы и элименты <th>
,
и <td>
имеют отдельные границы.
Свернуть границы таблицы
Свойство border-collapse
задает, будут ли границы таблиц свернуты в одну границу:
Если вы хотите установить границы только вокруг таблицы, укажите свойство border
для <table>
:
Ширина и высота таблицы
Ширина и высота таблицы определяются свойством width
и height
.
В примере ниже задается ширина таблицы 100 пиклелей, а высота 50 пиклелей:
Горизонтальное выравнивание таблицы
Свойство text-align
задает горизонтальное выравнивание (слева, справа, или по центру) контента в тегах <th>
или <td>
.
По умолчанию содержание элемента <th>
выравниваниет по центру и содержание элемента <td>
выравниваниет по левому краю.
В следующем примере выравнивает текст слева в элементе <th>
:
Вертикальное выравнивание таблицы
Свойство vertical-align
задает вертикальное выравнивание в (верхней, нижней или по центру) контент в <th>
или <td>
.
По умолчанию вертикальное выравнивание содержимого в таблице, будет по центру (для обоих элементов <th>
и <td>
).
Следующий пример задает вертикальное выравнивание текста в нижней части для элемента <td>
):
Отступы в таблице
Чтобы контролировать пространство между границей и содержимым в таблице, используйте свойство padding
в элементе <th>
и <td>
:
Горизонтальные разделители таблицы
Имя | Фамилия | Сбережение |
---|---|---|
Андрей | Щипунов | $100 |
Сергей | Щипунов | $150 |
Леонид | Щипунов | $300 |
Добавить свойство border-bottom
в <th>
и <td>
для горизонтальных разделителей:
Таблица при наведении
Используйте селектор :hover
в <tr>
для выделения строк таблицы при наведении:
Имя | Фамилия | Сбережение |
---|---|---|
Андрей | Щипунов | $100 |
Сергей | Щипунов | $150 |
Леонид | Щипунов | $300 |
Полосатая таблица
Имя | Фамилия | Сбережение |
---|---|---|
Андрей | Щипунов | $100 |
Сергей | Щипунов | $150 |
Леонид | Щипунов | $300 |
Для полосатой таблицы, использовать селектор nth-child()
и добавить background-color
на всех четных (или нечетных) строк таблицы:
Цвет заголовка таблицы
Пример ниже указывает цвет фона и цвет текста элемента <th>
:
Имя | Фамилия | Сбережение |
---|---|---|
Андрей | Щипунов | $100 |
Сергей | Щипунов | $150 |
Леонид | Щипунов | $300 |
Отзывчивая таблица
В отзывчивой таблице будет отображаться горизонтальная полоса прокрутки, если экран слишком мал для отображения полного содержимого:
Имя | Фамилия | Очки | Очки | Очки | Очки | Очки | Очки | Очки | Очки | Очки | Очки | Очки | Очки |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Андрей | Щипунов | 50 | 50 | 50 | 50 | 50 | 50 | 50 | 50 | 50 | 50 | 50 | 50 |
Сергей | Щипунов | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94 | 94 |
Леонид | Щипунов | 67 | 67 | 67 | 67 | 67 | 67 | 67 | 67 | 67 | 67 | 67 | 67 |
Добавьте контейнер элемент <div>
в overflow-x:auto
внутри элемента <table>
, чтобы сделать его отзывчивым:
Еще примеры
Установить шикарную таблицу
Пример демонстрирует, как создать шикарную таблицу.
Установить заголовок таблицы
Пример демонстрирует, как расположить заголовок таблицы.
Проверьте себя с помощью упражнений!
Свойства CSS таблицы
Свойство | Описание |
---|---|
border | Устанавливает все свойства границы в одном объявлении |
border-collapse | Устанавливает границы таблицы должны ли быть свернуты |
border-spacing | Устанавливает расстояние между границами соседних ячеек |
caption-side | Устанавливает размещение таблицы заголовка |
empty-cells | Устанавливает следует ли отображать границы и фон пустых ячеек в таблице |
table-layout | Устанавливает алгоритм макета компоновки для использования в таблице |
Блочная верстка сайта — урок с примером
Раньше на просторах Интернета был широко распространён табличный тип вёрстки, которому посвящена отдельная статья. Однако со временем этот подход к созданию структуры сайта устарел, и на смену ему пришла блочная вёрстка.
Отличия блочной вёрстки от табличной
Если табличная вёрстка подразумевает, что содержимое страницы находятся внутри тега <table>, то концепция блочной вёрстки основана на активном использовании универсальных тегов <div>, внутрь которых помещается содержимое, включая другие теги.
Блочная вёрстка лишена недостатков табличной — поисковыми системами она индексируется лучше, её код не такой развесистый, да и блоки <div>, которые так любят называть «слоями», изначально задумывались универсальными, то есть «для всего», тогда как <table> — это таблица, которую нужно использовать для отображения табличных данных и не более того.
Единственный ощутимый минус блочной вёрстки — сделанные на ней сайты могут по-разному отображаться в обозревателях. Чтобы этого избежать, нужно делать вёрстку «кроссбраузерной», то есть одинаково отображаемой любым обозревателем.
Суть блочной вёрстки
В графическом редакторе создаётся макет сайта: размечается, где какая область страницы (шапка, низ, боковая панель, основной контент) будет находиться и сколько места занимать, готовятся картинки, фоны.
Каждая часть страницы помещается в свой блок <div>: верх сайта — в первый, меню — во второй, контент — в третий и т. д. Каждый блок наполняется содержимым средствами HTML, а также позиционируется и оформляется с помощью CSS-разметки.
Конечный HTML-документ представляет собой набор блоков <div> с контентом внутри. Оформление зачастую находится в отдельном CSS-файле, подключенном к странице тегом <link>, или как минимум в контейнере <style> секции <head>.
Принципы блочной вёрстки
Первый — конечно же, повсеместное использование тега <div>, который можно назвать базовым элементом блочной структуры, но об этом было сказано уже достаточно много.
Второе правило — принцип разделения кода, согласно которому содержимое от оформления нужно отделять. Говоря проще и ближе к нашему случаю: HTML — отдельно, CSS — отдельно (желательно в разные файлы). Такой подход делает структуру понятней. Программисту не нужно открывать CSS, дизайнеру — HTML. Все смотрят свой код и не мешают друг другу. Идеально.
Третий принцип — таблицы нужно использовать не везде, а по необходимости, при этом полностью отказываться от них так же странно, как и применять не к месту.
Пример блочной вёрстки
Но, сколько не теоретизируй, а понимать всё проще на примере.
Итак, у нас есть макет (рисунок ниже). Условный, конечно — просто разметка, ведь цель примера — как можно наглядней объяснить принцип создания блочной вёрстки. Зная базу, навести красоту и усложнить макет вы сможете и сами, а я лучше не буду перегружать пример.
Согласно макету, страница сайта будет содержать пять блоков: «шапку», навигационное меню, боковую панель, основной блок с контентом и «ноги».
Сначала создадим HTML-страницу: обозначим структуру, разметим её. HTML-код будет таким:
<!DOCTYPE html> <html> <head> <title>Блочная вёрстка</title> <link rel="stylesheet" type="text/css" href="style.css"> </head> <body> <div> <div> <h3>header (шапка сайта)</h3> </div> <div> <h3>Блок навигации</h3> </div> <div> <h3>Левая панель</h3> </div> <div> <h3>Основной контент страницы</h3> </div> <div> </div> <div> <h3>footer (низ сайта)</h3> </div> </div> </body> </html>
Разберём некоторые моменты.
<div> — это блок-родитель, внутри которого расположились все остальные блоки. Как ячейки таблицы внутри <table>. Назначение дочерних контейнеров должно быть понятно, за исключением разве что блока <div>. Это вспомогательный слой, его смысл будет понятен, когда вы увидите код CSS.
Если открыть HTML-файл в браузере, не подключая таблицу стилей, страница будет выглядеть так.
Теперь добавим файл CSS, код которого приведён ниже.
body { background: #FFF; color: #000; font-family: Arial, sans-serif; font-size: 14px; } #header { background: #F5DEB3; width: 100%; height: 55px; } #container { background: #FFD700; margin: auto auto; text-align: center; width: 80%; height: 400px; } #navigation { background: #FE9798; width: 100%; height: 25px; } #sidebar { background: #40E0D0; float: left; width: 20%; height: 280px; } #content { background: #DCDCDC; float: right; width: 80%; height: 280px; } #clear { clear: both; } #footer { background: #00BFFF; width: 100%; height: 40px; }
С помощью стилей мы последовательно оформляем содержимое тега <body> и всех находящихся внутри контейнеров с помощью ранее изученных правил.
#clear { clear:both; } запрещает обтекание элемента слева и справа. Если убрать это правило, вёрстка «поедет» и низ сайта перестанет корректно отображаться.
CSS творит чудеса, и с ним наша HTML-страница примет уже совсем другой вид.
Вот и весь смысл блочной структуры. Дальше можно только наполнять сайт содержимым и усложнять оформление, но делаться это будет всё равно по изложенному выше принципу. Также посмотрите статью про вёрстку сайта из PSD макета, там эти принципы показаны более наглядно.
Полезные ссылки:
HTML генератор таблиц Div | 𝗖𝗢𝗠 𝗧𝗔𝗕𝗟𝗘.𝗖𝗢𝗠
Quick Create
Настройте параметры и щелкните поле, чтобы создать таблицу!
Настройки
Таблица / Div:
Теги Div Теги таблицы
Граница:
Ширина:
% ПВ
Cell Padding:
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
x
х
Заменить HTML-таблицы с divs
В эпоху адаптивного веб-дизайна старая тенденция создания веб-сайтов с использованием таблиц HTML больше не может использоваться. Вы должны использовать теги div и стилизовать их по мере необходимости. Эта функция HTML Cleaner предлагает вам простой способ заменить все теги таблицы тегами div, имеющими правильные классы.
В этом случае замены контента будет недостаточно, вам придется добавить код CSS в таблицу стилей вашего сайта.Прокрутите вниз, чтобы найти требуемый код в нижней части этой страницы и откорректируйте его, если это необходимо.
4 простых шага:
- Вставьте таблицу в редактор
- Убедитесь, что опция очистки Заменить теги таблицы на div включена
- Очистите документ
- Разработайте ваши таблицы, используя CSS ниже
Почему и как использовать?
Смотрите видео в HD.
Два примера ниже демонстрируют два подхода.Первая была построена с использованием табличных тегов, а вторая — в стиле DIV.
Телефоны <Й> <сильный> Имя <Й> Телефон <Й> & NBSP;
John 0123 456 785 Cassie 9876 532 432 Телефоны
<сильный> ИмяТелефон& NBSP;Джон0123 456 785CassieТаблица, построенная с использованием классических тегов таблицы HTML:
месяц Расходы Примечания январь $ 20 Ремонт автомобилей февраль $ 130 Мебель март $ 30 Чистка бассейна Сумма 180 900 $ Все сделано Та же таблица, построенная с использованием только div:
Стилизация ваших столов div
Минималистские стили
Очень простой стиль для столов div.Он даже не добавляет границы ячеек, он просто выравнивает элементы правильно.
.rTable {display: table; } .rTableRow {display: table-row; } .rTableHeading {display: table-header-group; } .rTableBody {display: table-row-group; } .rTableFoot {display: table-footer-group; } .rTableCell, .rTableHead {display: table-cell; }Пример стилей таблицы div
Мы использовали css ниже для нашей демонстрационной таблицы, которую вы можете увидеть выше. Он дает границы ячейкам и выделяет верхний и нижний колонтитулы.
.rTable { дисплей: стол; ширина: 100%; } .rTableRow { дисплей: таблица-строка; } .rTableHeading { дисплей: table-header-group; цвет фона: #ddd; } .rTableCell, .rTableHead { дисплей: таблица-ячейка; обивка: 3px 10px; граница: 1.HTML — Как создать таблицу только с использованием тега и Css Переполнение стека
- Товары
- Клиенты
- Случаи использования
.
- Переполнение стека Публичные вопросы и ответы
- Команды Частные вопросы и ответы для вашей команды
- предприятие Частные вопросы и ответы для вашего предприятия
- работы Программирование и связанные с ним технические возможности карьерного роста
- Талант Нанимать технический талант
- Реклама
Использование тега Div для создания таблиц
- Веб-дизайн и разработка
- CSS3
- Использование тега Div для создания таблиц
Джон Пол Мюллер
Создание таблиц может быть подвержено ошибкам и затруднено при использовании старых тегов HTML. Кроме того, они оказываются негибкими время от времени. Можно создавать таблицы, используя другую технику. Все, что вам нужно, это серия каскадных тегов
для выполнения задачи.Кредит: © iStockphoto.com / Антон Черственков
В прошлом многие разработчики использовали таблицы для самых разных задач. Конечно, есть использование таблиц для отображения данных. Однако табличные схемы также полезны для создания форм, чтобы гарантировать, что различные элементы выровнены предсказуемым образом. Это второе использование таблиц является проблематичным, поскольку оно сбивает с толку некоторые программы, такие как программы чтения с экрана. Проблема становится в том, чтобы определить хорошо организованную страницу, не создавая проблем для людей, просматривающих ее.
Использование тегов
для создания таблицы позволяет зрителям с одинаковой легкостью видеть таблицу или логическое расположение элементов управления. Эта методика также имеет преимущество, заключающееся в том, что не следует путать программы чтения с экрана и другое программное обеспечение.Определение HTML для таблицы
выглядит как создание таблицы с использованием более старых тегов, за исключением того, что вам не нужно беспокоиться о странном расположении тайных тегов, чтобы сделать это. Вот HTML-код для таблицы, которая содержит заголовок, заголовки и две строки содержимого.Это таблица
Заголовок 1
Заголовок 2
Заголовок 3
Строка 1, столбец 1
Строка 1, столбец 2
Строка 1, столбец 3
Строка 2, столбец 1
Строка 2, столбец 2
Строка 2, столбец 3
Обратите внимание, что каждый уровень
определяется с использованием легко распознаваемого имени, такого как Таблица, Заголовок, Заголовок, Строка и Ячейка.Использование этого метода именования значительно упрощает определение того, что должен делать каждый уровень таблицы. Вы можете найти много разных альтернатив этому подходу онлайн, но этот базовый подход будет вам полезен.CSS для этой таблицы использует несколько специальных свойств и немного умного форматирования. Вот CSS использовать
.