Да, вы можете использовать их, например, я использую их для упрощения стилизации групп данных, например так:
thead th { width: 100px; border-bottom: solid 1px #ddd; font-weight: bold; }
tbody:nth-child(odd) { background: #f5f5f5; border: solid 1px #ddd; }
tbody:nth-child(even) { background: #e5e5e5; border: solid 1px #ddd; }
<table>
<thead>
<tr><th>Customer</th><th>Order</th><th>Month</th></tr>
</thead>
<tbody>
<tr><td>Customer 1</td><td>#1</td><td>January</td></tr>
<tr><td>Customer 1</td><td>#2</td><td>April</td></tr>
<tr><td>Customer 1</td><td>#3</td><td>March</td></tr>
</tbody>
<tbody>
<tr><td>Customer 2</td><td>#1</td><td>January</td></tr>
<tr><td>Customer 2</td><td>#2</td><td>April</td></tr>
<tr><td>Customer 2</td><td>#3</td><td>March</td></tr>
</tbody>
<tbody>
<tr><td>Customer 3</td><td>#1</td><td>January</td></tr>
<tr><td>Customer 3</td><td>#2</td><td>April</td></tr>
<tr><td>Customer 3</td><td>#3</td><td>March</td></tr>
</tbody>
</table>
Вы можете посмотреть пример здесь . Это будет работать только в новых браузерах, но это то, что я поддерживаю в моем текущем приложении: вы можете использовать группирование для JavaScript и т. Д. Главное, это удобный способ визуально сгруппировать строки, чтобы сделать данные намного более читабельными , Конечно, есть и другие варианты использования, но, насколько это применимо, этот пример является наиболее распространенным для меня.
tbody
или несколько?<tbody>
. Когда вы начинаете вкладывать таблицы, это обычно создает реальные проблемы с навигацией для программы чтения с экрана.<tbody>
элементов описывают отдельные группы в таблице, как было объяснено в ответе. Также я должен добавить, что в целом лучше ориентироваться на ячейки для фона, поэтому CSS должен быть, например,tbody:nth-child(odd) td { background: #f5f5f5; }
:nth-child()
использование CSS для связанной демонстрации, множественное число<tbody>
будет работать в любом браузере.Да. От DTD
Так что ожидается один или несколько. Затем он продолжает говорить
источник
tbody
элементами все в порядке) остается. В частности, теперь вам разрешено помещать одинtfoot
элемент после того,tbody
если вам нравится . (Они аккуратно обошли стороной аспект DTD» говоря, что они не предоставляют один .) :-)<tr>
поэтому он также может быть равен нулю (т. Е. Tbody или tr означает, что это может быть просто tr, а не tbody.)Согласно этому примеру это можно сделать: w3-struct-tables .
источник
Проблема Мартина Столяра вызвана неправильным пониманием
<caption>
тега.<caption>
Тег определяет заголовок таблицы.<caption>
Тег должен быть первым потомком<table>
тега.Вы можете указать только одну подпись к таблице.
Также обратите внимание, что
scope
атрибут должен быть размещен на<th>
элементе, а не на<tr>
элементе.Правильный способ написания таблицы из нескольких заголовков с несколькими заголовками будет выглядеть примерно так:
источник
caption
Тег должен следовать открывающийtable
тег. developer.mozilla.org/en-US/docs/Web/HTML/Element/tablescope="rowgroup"
(вместоcol
) дляtbody
заголовков. Смотрите пример .Да. Я использую их для динамического сокрытия / раскрытия соответствующей части таблицы, например, курса. А именно
Может быть предусмотрена кнопка для переключения между всем или только текущим днем путем манипулирования телами без индивидуальной обработки множества строк.
источник
РЕДАКТИРОВАТЬ:
caption
тег принадлежит к таблице и, следовательно, должен существовать только один раз. Не связывайте acaption
с каждымtbody
элементом, как я:ПЛОХОЙ ПРИМЕР ВЫШЕ: НЕ КОПИРУЙТЕ
Приведенный выше пример не отображается так, как вы ожидаете, потому что запись в таком виде указывает на неправильное понимание
caption
тега. Вам понадобится много CSS-хаков, чтобы он правильно отображался, потому что вы будете идти против стандартов.Я искал стандарты W3Cs для
caption
тега, но не смог найти явного правила, согласно которомуcaption
в таблице должен быть только один элемент, но на самом деле это так.источник
Кроме того, если вы запустите HTML-документ с несколькими
<tbody>
тегами через HTML-валидатор W3C с HTML5 DOCTYPE, он успешно пройдет проверку.источник
Я создал JSFiddle, где у меня есть два вложенных ng-повторения с таблицами и родительский ng-повтор на tbody. Если вы проверите любую строку в таблице, вы увидите, что есть шесть элементов tbody, то есть родительский уровень.
HTML
(Примечание: это заполняет DOM, если у вас много данных на обоих уровнях, поэтому я работаю над директивой для извлечения данных и замены, т.е. добавление в DOM при нажатии на родительский элемент и удаление при нажатии на другой или тот же родительский элемент снова. Чтобы получить такое поведение, которое вы найдете в Prisjakt.nu , если вы прокрутите вниз до перечисленных компьютеров и щелкните по строке (не по ссылкам). Если вы сделаете это и осмотрите элементы, вы увидите, что добавлен tr и затем удаляется, если родитель нажимается снова или другой.)
источник