Цвет рамки таблицы в html

  • Рамка таблицы
  • Размер таблицы
  • Выравнивание текста
  • Чередование фонового цвета строк таблицы
  • Изменение фона строки при наведении курсора
  • Выравнивание таблицы по центру

Табличные данные — информация, которую можно отобразить в виде таблицы и логически разделить по столбцам и строкам. Для отображения табличных данных на веб-страницах используется HTML тег <table>, представляющий из себя контейнер с содержимым таблицы. Контент HTML таблицы описывается построчно, каждая строка начинается с открывающего тега <tr> и заканчивается закрывающим тегом </tr>.

Внутри тега <tr> располагаются ячейки таблицы, представленные тегами <th> или <td>. Именно ячейки содержат весь контент таблицы, отображаемый на веб-странице.

Рамка таблицы

По умолчанию HTML таблица на веб-странице отображается без рамки, для добавления рамки к таблице, как и ко всем другим элементам, используется CSS свойство border. Но стоит обратить внимание на то, что если добавить рамку только к элементу <table>
, то она отобразиться вокруг всей таблицы. Для того, чтобы ячейки таблицы тоже имели рамку, надо будет установить свойство border и для элементов <th> и <td>.

table, th, td { border: 1px solid black; }

Попробовать »

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

Даже если убрать промежутки между ячейками с помощью значения 0 свойства border-spacing, то рамки ячеек будут соприкасаться друг с другом, удваиваясь. Для объединения рамок ячеек используется свойство border-collapse. Оно может принимать два значения:

  • separate: является значением по умолчанию. Ячейки отображаются на небольшом расстоянии друг от друга, каждая ячейка имеет свою собственную рамку.
  • collapse: соединяет соседние рамки в одну, все промежутки между ячейками, а также между ячейками и рамкой таблицы игнорируются.

Попробовать »

Размер таблицы

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

th, td { padding: 7px; }

Попробовать »

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

table { width: 70%; }  th { height: 50px; }

Попробовать »

Выравнивание текста


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

CSS свойство vertical-align позволяет управлять выравниванием текстового содержимого по вертикали. По умолчанию текст выровнен вертикально по центру ячеек. Вертикальное выравнивание можно переопределить с помощью одного из значений свойства vertical-align:

  • top: текст выравнивается по верхней границе ячейки
  • middle: выравнивает текст по центру (значение по умолчанию)
  • bottom: текст выравнивается по нижней границе ячейки
<!DOCTYPE html>  <html>   <head>   <meta charset="utf-8">   <title>Название документа</title>   <style>   table, td, th {   border: 1px solid black;    border-collapse: collapse;   }   table { width: 70% }   td { text-align: right; }   th { height: 50px; }   .test1 { vertical-align: top; }   .test2 { vertical-align: bottom; }   </style>   </head>     <body>   <table>   <tr><th class="test1">Имя</th><th class="test2">Фамилия</th></tr>   <tr><td>Гомер</td><td>Симпсон</td></tr>   <tr><td>Мардж</td><td>Симпсон</td></tr>   </table>   </body>  </html>  

Попробовать »

Чередование фонового цвета строк таблицы


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

<!DOCTYPE html>  <html>   <head>   <meta charset="utf-8">   <title>Название документа</title>   <style>   table {   width: 70%;   border-collapse: collapse;   }   td, th {   border: 1px solid #98bf21;   padding: 3px 7px 2px 7px;   }   th {   text-align: left;   padding: 5px;   background-color: #A7C942;   color: #fff;   }   .alt td { background-color: #EAF2D3; }   </style>   </head>   <body>   <table>   <tr><th>Имя</th><th>Фамилия</th><th>Положение</th></tr>   <tr><td>Гомер</td><td>Симпсон</td><td>отец</td></tr>   <tr class="alt"><td>Мардж</td><td>Симпсон</td><td>мать</td></tr>   <tr><td>Барт</td><td>Симпсон</td><td>сын</td></tr>   <tr class="alt"><td>Лиза</td><td>Симпсон</td><td>дочь</td></tr>   </table>   </body>  </html>  

Попробовать »

Добавлять атрибут class
к каждой второй строке довольно утомительное занятие. В CSS3 был добавлен псевдо-класс :nth-child, позволяющий решить эту проблему альтернативным путем. Теперь эффекта чередования можно достичь исключительно средствами CSS, не прибегая к изменению HTML-разметки документа. С помощью псевдо-класса :nth-child можно выбрать все четные или нечетные строки таблицы, используя одно из ключевых слов: even (четные) или odd (нечетные):

tr:nth-child(odd) { background-color: #EAF2D3; }

Попробовать »

Изменение фона строки при наведении курсора

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

Реализовать такой эффект очень просто, для этого нужно добавить псевдо-класс :hover к селектору строки таблицы и задать нужный цвет фона:

tr:hover { background-color: #E0E0FF; }

Попробовать »

Выравнивание таблицы по центру

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

table { margin: 10px auto; }

Попробовать »

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

table { margin: 10px auto 30px; }

puzzleweb.ru

Как сделать рамку для таблицы

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

Ячейка

Ячейка

Ячейка

Ячейка
<table style="border: 1px solid red;">   <tr>   <td>Ячейка   <td>Ячейка   <tr>   <td>Ячейка   <td>Ячейка  </table>

Установить рамку каждой ячейке также можно с помощью атрибута style. Но предпочтительней стиль вынести в тег style или файл .css: кода меньше, возможности шире, удобства больше (чтобы изменить цвет рамки у всех ячеек, достаточно поменять значение один раз).

Ячейка

Ячейка

Ячейка

Ячейка

<table style="border: 1px solid red;">   <tr>   <td style="border: 1px solid red;">Ячейка   <td style="border: 1px solid red;">Ячейка   <tr>   <td style="border: 1px solid red;">Ячейка   <td style="border: 1px solid red;">Ячейка  </table>    <!-- равнозначная запись -->    <style>  .raz,  .raz td {   border: 1px solid red;  }  </style>    <table class="raz">   <tr>   <td>Ячейка   <td>Ячейка   <tr>   <td>Ячейка   <td>Ячейка  </table>

Убрать промежутки от ячеек до краёв таблицы

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка

Ячейка
<style>    /* один из возможных вариантов сделать отступы вокруг ячеек таблицы */    .raz {   border-spacing: 0;   padding: 0 2em 3em 0; /* значения left    
и top последних ячеек */
} .raz, .raz td { position: relative; border: 1px solid red; } .raz td:nth-child(2) { left: 1em; } .raz td:nth-child(3) { left: 2em; /* каждая дополнительная ячейка сдвигается на +1 единицу */ } .raz tr:nth-child(2) td { top: 1em; } .raz tr:nth-child(3) td { top: 2em; } .raz tr:nth-child(4) td { top: 3em; } </style> <table class="raz"> <tr> <td>Ячейка <td>Ячейка <td>Ячейка <tr> <td>Ячейка <td>Ячейка <td>Ячейка <tr> <td>Ячейка <td>Ячейка <td>Ячейка <tr> <td>Ячейка <td>Ячейка <td>Ячейка </table>

Скрыть пустые ячейки в таблице c border-collapse: collapse; можно с помощью псевдоклассов :empty или :blank.

Жирные внешние границы таблицы

Ячейка

Ячейка

Ячейка

Ячейка
<style>  .raz {   border-collapse: collapse;   border: 4px solid red;  }  .raz td {   border: 1px solid red;  }  </style>    <table class="raz">   <tr>   <td>Ячейка   <td>Ячейка   <tr>   <td>Ячейка   <td>Ячейка  </table>

Таблица без границ аки сетка без внешней рамки

Ячейка

Ячейка

Ячейка

Ячейка

<style>  .raz {   border-collapse: collapse;   border-style: hidden;  }  .raz td {   border: 1px solid red;  }  </style>    <table class="raz">   <tr>   <td>Ячейка   <td>Ячейка   <tr>   <td>Ячейка   <td>Ячейка  </table>

Свойство border у tr

Заголовок

Заголовок

Ячейка

Ячейка

Ячейка

Ячейка
<style>  .raz {   border-collapse: collapse;  }  .raz tr:first-child {   border-bottom: 1px solid red;  }  .raz th+th,  .raz td+td {   padding-left: 1em; /* отступы между столбцами без вертикальных рамок */  }  </style>    <table class="raz">   <tr>   <th>Заголовок   <th>Заголовок   <tr>   <td>Ячейка   <td>Ячейка   <tr>   <td>Ячейка   <td>Ячейка  </table>

Свойство padding у table при border-collapse: collapse;

Ячейка

Ячейка

Ячейка

Ячейка

<style>  .raz {   border-collapse: collapse;   outline: 1px solid red; /* outline можно задавать только для четырёх сторон одновременно */    outline-offset: 2px;   margin: 3px; /* outline-width + outline-offset = 1px + 2px = 3px */   }  .raz,  .raz td {   border: 1px solid red;  }  </style>    <table class="raz">   <tr>   <td>Ячейка   <td>Ячейка   <tr>   <td>Ячейка   <td>Ячейка  </table>

Отступы внутри ячейки таблицы

Расстояние от содержимого до края ячейки определяет свойство padding.

Ячейка

Ячейка

Ячейка

Ячейка
<style>  .raz {   border-collapse: collapse;  }  .raz td {   border: 1px solid red;   padding: .3em 1em; /* значения внутренних отступов ячейки от верхнего и нижнего и от правого и левого краёв */  }  </style>    <table class="raz">   <tr>   <td>Ячейка   <td>Ячейка   <tr>   <td>Ячейка   <td>Ячейка  </table>

shpargalkablog.ru

Как изменить цвет ячейки

Давайте посмотрим, как выглядит код в CSS, в котором задан цвет для ячейки.

td {  background-color: цвет-фона; }

Разумеется, изменять цвета можно и у table, и у td, и у th. Давайте попробуем придать нашей таблице умножения более солидный вид.

Добавим стили для ячеек-заголовков с тегом th, а также для ячеек по диагонали, в которых расположены квадраты чисел:

<!DOCTYPE html> <html> <head>  <meta charset="utf-8">  <title>Таблица умножения</title>  <style>  table {  border: solid 1px blue;  border-collapse: collapse;  }   td, th {  border: solid 1px blue;  padding: 10px;  }   th {  background-color: #eeeeee;  }  </style> </head> <body> <table>  <caption>Таблица умножения</caption>  <tr>  <th>*</th>  <th>2</th>  <th>3</th>  </tr>  <tr>  <th>2</th>  <td style="background-color: greenyellow">4</td>  <td>6</td>  </tr>  <tr>  <th>3</th>  <td>6</td>  <td style="background-color: greenyellow">9</td>  </tr> </table> </body> </html>

Результат в браузере:
Раскрашенная таблица умножения

Как изменить цвет рамки в таблице

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

  1. тип линии, в нашем случае solid (сплошная)
  2. толщина линии, в нашем случае 1px
  3. цвет линии, в нашем случае синий

Напомним ещё раз, как выглядит задание цвета рамки для ячейки:

td {  border: 1px solid blue; }

Как изменить цвет строки в таблице

Итак, мы с вами научились менять цвета ячеек, а также ячеек-заголовков, используя возможности CSS. Если мы указываем стили для таких тегов, как th или td, то должны понимать, что применимы стили будут и к остальным тегам.

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

.rowGreen {  background-color:green; }

А чтобы изменить цвет с помощью этого класса определённые строки нужно сделать следующее:

<!DOCTYPE html> <html> <head>  <meta charset="utf-8">  <title>Таблица с чередованием цвета в строках</title>  <style>  table {  border: solid 1px blue;  border-collapse: collapse;  }   td, th {  border: solid 1px blue;  padding: 10px;  }   .rowGreen {  background-color: lightgreen;  }  </style> </head> <body> <table>  <caption>Таблица с чередованием цвета в строках</caption>  <tr class="rowGreen">  <th>1</th>  <th>2</th>  <th>3</th>  <th>4</th>  <th>5</th>  </tr>  <tr>  <th>1</th>  <th>2</th>  <th>3</th>  <th>4</th>  <th>5</th>  </tr>  <tr class="rowGreen">  <th>1</th>  <th>2</th>  <th>3</th>  <th>4</th>  <th>5</th>  </tr> </table> </body> </html>

И результат в браузере:
Таблица с чередованием цвета в строках

Как изменить цвет текста в таблице

Для того, чтобы изменить цвет текста в таблице используется свойство color. Применять его можно к самым разным элементам: к table, tr, th, td. В зависимости от этого цвет в выбранном элементе будет изменён. Например, для всей таблицы зададим зелёный цвет шрифта:

table {  color: green;  ... }

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

webshake.ru

При создании веб страниц очень часто необходимо представить некоторое содержимое страницы в виде таблиц.

Создание таблиц в HTML - фон таблицы - рамка таблицы - объединение ячеек

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

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

  • HTML цвета — таблица HTML кодов цветов
  • Быстрое введение в HTML5 для веб-мастеров
  • Параграфы и выравнивание текста в HTML

За создание таблиц в HTML отвечает тег <table> и закрывающий тег </table>. Но вам наверняка уже известно, что таблицы состоят из строчек и ячеек. Поэтому для того, чтобы создать таблицу, нам необходимы еще два тега: это тег <tr></tr> который отвечает за создание строк, и тег, <td></td> отвечающий за создание ячеек.

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

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

У вас должно получиться следующее:

Создание таблицы состоящей из четырех ячеек

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

Вначале мы рассмотрим атрибуты, которые присущи тегам <table></table>. Для того, чтобы видеть как будет меняться наша таблица, вы можете добавлять эти атрибуты к тегам <table></table> и, обновляя страницу, смотреть как будет выглядеть таблица в браузере. Для удобства я не буду приводить весь код страницы, а только код касающийся тега <table> т. е. то что мы будем изменять.

И так тег <table> имеет следующие атрибуты:

border — задает ширину рамки таблицы в пикселях, записывается так: <table border=»2″> </table>.

bordercolor – цвет рамки таблицы, данный атрибут поддерживает не все браузеры, поэтому вы можете и не увидеть заданный цвет рамки: <table border=»2″ bordercolor=»#548DD4″> </table>

Мы задали ширину рамки 2 пикселя, синего цвета, таблица примет следующий вид:

Создание рамки таблицы - цвет рамки

width – задает ширину таблицы в пикселях или процентах:

height – высота таблицы в пикселях или процентах: <table border=»2″ bordercolor=»#548DD4″ width=»250″ height=»150″> </table>

Ширина таблицы будет 250 пикселей, а высота 150 пикселей, таблица будет выглядеть так:

Учтанавливаем высоту и ширину таблицы

align – выравнивание таблицы;

align=left – таблицы будет выровнена по левому краю;

align=right – таблица будет выровнена по правому краю:

Наша таблица должна выровняться по правому краю.

bgcolor – цвет фона таблицы, bgcolor=#FFC000 – цвет фона таблицы будет желтый:

Таблица получит следующий вид:

Фон таблицы

background – при помощи данного атрибута можно задать изображение, которое будет фоном таблицы.

В качестве примера сохраните маленькое изображение, которое вы видите в скобках (fon) в ту папку, где у вас находится страница с таблицей, а к тегу <table> добавьте background=»fon.gif » весь код:

Таблица примет следующий вид:

Изображение в виде фона таблицы

сellpadding – атрибут, задающий левый, правый, верхний и нижний отступы внутри ячейки. Например, если к нашему тегу <table> добавить сellpadding=10, то текст, написанный внутри ячеек, получит отступ.

cellspacing – задает отступ между ячейками таблицы.

Если вы присмотритесь к нашей таблице, то увидите, что между рамками ячеек имеется небольшое пространство, это и есть отступ между ячейками, он задается по умолчанию. Для того, чтобы его убрать, достаточно в теге <table> прописать cellspacing=0. Весь код:

В результате наши ячейки прижались друг к другу, а текст внутри ячеек получил отступ:

Внутренние и внешние отступы в таблице

hspace — задает промежуток от таблицы в лево и в право в пикселях, записывается так: hspace=20

nowrap – запрещает перенос слов в ячейке, записывается просто nowrap

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

Теперь рассмотрим атрибуты тега <td>, некоторые из них такие же, как и атрибуты тега <table>

width — ширина ячейки в пикселях или в процентах.

height – высота ячейки в пикселях или процентах.

Например, зададим ширину первой ячейки первой строки в 30% — width=30% , а высоту первой ячейки второй строки в 100px. Код будет таким:

Наша таблица примет следующий вид:

Высота и ширина ячейки таблицы

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

align – выравнивает содержимое ячеек, имеет следующие значения:

align=»lef» – содержимое ячейки будет выровнено по левому краю;

align=»right» – содержимое будет выровнено по правому краю;

align=»center» – содержимое будет выровнено по центру ячейки.

Добавим эти атрибуты и значения в наш код и выровняем содержимое 1 — й ячейки по левому краю (по левому краю содержимое выравнивается по умолчанию, однако в некоторых случаях данный атрибут необходим), содержимое 2 – й ячейки выровняем по правому краю, а 4 -й по центру.

bgcolor – при помощи данного атрибута можно задать цвет ячейки.

background – устанавливает изображение в виде фона ячейки.

С данными атрибутами мы уже встречались, рассматривая атрибуты тега <table>. Работают они одинаково, только в этом случае ими задается фон ячейки. Например, зададим цвет фона 2-й ячейки желтым, а в качестве фона 4-й ячейки установим следующее изображение (fon).

Для этого в наш код добавим необходимые атрибуты, для наших ячеек bgcolor=»#FFFF00″ для 2-й ячейки и background= «fon.jpg» для 4-й ячейки. В результате наша таблица станет выглядеть так:

Фон ячейки таблицы

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

bordercolor – задает цвет рамки ячейки.

C этим атрибутом мы так же встречались, рассматривая атрибуты тега <table>. Напоминаю, что он работает не во всех браузерах. Обратите внимание на то, что у тега <td> нет атрибута border обозначающего рамку ячейки. Зададим цвет рамки 2 – й ячейки красным для этого ко второй ячейке добавим атрибут bordercolor=»#FF0000″

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

valign – он производит выравнивание содержимое ячеек по вертикали.

Имеет следующие значения:

valign=»top» – выравнивание содержимого ячейки по верхнему краю;

valign=»bottom» – выравнивание содержимого ячейки по нижнему краю;

valign=»middle» – выравнивание посередине ячейки;

valign=»baseline» – выравнивание содержимого ячейки по базовой линии.

Добавим эти атрибуты к каждой из наших 4-х ячеек.

Наша таблица примет следующий вид:

Выравнивание ячеек таблицы по вертикали

Последнее что нам необходимо рассмотреть в этом уроке, это объединение ячеек таблицы. Для того чтобы объединить несколько ячеек в строке, существует атрибут colspan=»» где в кавычках указывается количество ячеек которое необходимо объединить.

Чтобы объединить ячейки по вертикали т. е. в столбце, необходимо использовать атрибут rowspan=»» где в кавычках указывается количество ячеек, которое необходимо объединить.

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

Пример таблицы

Теперь объединим 1-ю и 2-ю ячейку в строке и 3-ю, 6-ю и 7-ю ячейку в ряду. Код нашей таблицы будет следующий:

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

Объединение ячеек таблицы

Это были последние атрибуты ячеек. Как вы можете видеть атрибутов у тегов <table> и <td> множество. Это позволяет размещать в таблицах различное содержимое, позиционируя его и оформляя необходимым образом.

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

Материал подготовлен проектом: webmastermix.ru

  • Как сделать ссылку в HTML — виды ссылок — изображение ссылка
  • Как вставлять картинки и производить их позиционирование в html
  • Форматирование текста в HTML
  • Как изменять цвет текста в html документе
  • Как задавать цвет фона HTML документа

webmastermix.ru

Цвет фона ячеек

Цвет фона одновременно всех ячеек таблицы устанавливается через свойство background, которое применяется к селектору TABLE. При этом следует помнить о правилах использования стилей, в частности, наследовании свойств элементов. Если одновременно с TABLE задать цвет у селектора TD или TH, то он и будет установлен в качестве фона (пример 1).

Пример 1. Цвет фона

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html>  <head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  <title>Таблицы</title>  <style type="text/css">  TABLE {  background: maroon; /* Цвет фона таблицы */  color: white; /* Цвет текста */  }  TD {  background: navy; /* Цвет фона ячеек */  }  </style>  </head>   <body>  <table cellpadding="4" cellspacing="1">  <tr><th>Заголовок 1</th><th>Заголовок 2</th></tr>  <tr><td>Ячейка 3</td><td>Ячейка 4</td></tr>  </table>  </body> </html>

В данном примере получим синий цвет фона у ячеек (тег <td>) и красный у заголовка (тег <th>). Это связано с тем, что стиль для селектора TH не определен, поэтому «просвечивается» фон родителя, в данном случае, селектора TABLE. А цвет для селектора TD указан явно, вот ячейки и «заливаются» синим цветом.

То же самое происходит и с цветом текста. Для всех элементов таблицы в примере он установлен белым.

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

Изменение цвета фона

Рис. 1. Изменение цвета фона

Поля внутри ячеек

Полем называется расстояние между краем содержимого ячейки и ее границей. Обычно для этой цели применяется атрибут cellpadding тега <table>. Он определяет значение поля в пикселах со всех сторон ячейки. Допускается использовать стилевое свойство padding, добавляя его к селектору TD, как показано в примере 2.

Пример 2. Поля в таблицах

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html>  <head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  <title>Таблицы</title>  <style type="text/css">  TABLE {  background: white; /* Цвет фона таблицы */  color: white; /* Цвет текста */  }  TD, TH {  background: maroon; /* Цвет фона ячеек */  padding: 5px; /* Поля вокруг текста */  }  </style>  </head>   <body>  <table cellspacing="1">  <tr><th>Заголовок 1</th><th>Заголовок 2</th></tr>  <tr><td>Ячейка 3</td><td>Ячейка 4</td></tr>  </table>  </body> </html>

В данном примере с помощью группирования селектором поля установлены одновременно для селектора TD и TH.

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

Поля в ячейках

Рис. 2. Поля в ячейках

Если применяется стилевое свойство padding для ячеек таблицы, то действие атрибута cellpadding тега <table> игнорируется.

Границы и рамки

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

Использование атрибута cellspacing

Известно, что атрибут cellspacing тега <table> задает расстояние между ячейками таблицы. Если используется разный цвет фона таблицы и ячеек, то между ячейками возникнет сетка линий, цвет которых совпадает с цветом таблицы, а толщина равна значению атрибута cellspacing в пикселах. В вышеприведенном примере 2 этот эффект показан, поэтому повторять его не будем.

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

Применение свойства border

Стилевое свойство border одновременно задает цвет границы, ее стиль и толщину вокруг элемента. Когда требуется создать отдельные линии на разных сторонах, лучше использовать его производные — border-left, border-right, border-top и border-bottom, они соответственно определяют границу слева, справа, сверху и снизу.

Применяя свойство border к селектору TABLE, мы добавляем рамку вокруг таблицы в целом, а к селектору TD или TH — рамку вокруг ячеек (пример 3).

Пример 3. Добавление двойной рамки

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html>  <head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  <title>Таблицы</title>  <style type="text/css">  TABLE {  background: #dc0; /* Цвет фона таблицы */  border: 5px double #000; /* Рамка вокруг таблицы */  }  TD, TH {  padding: 5px; /* Поля вокруг текста */  border: 1px solid #fff; /* Рамка вокруг ячеек */  }  </style>  </head>  <body>  <table>  <tr><th>Заголовок 1</th><th>Заголовок 2</th></tr>  <tr><td>Ячейка 3</td><td>Ячейка 4</td></tr>  </table>  </body> </html>

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

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

Граница вокруг таблицы и ячеек

Рис. 3. Граница вокруг таблицы и ячеек

Обратите внимание, что в месте состыковки ячеек образуются двойные линии. Они получаются опять же за счет действия атрибута cellspacing тега <table>. Хотя в коде примера этот атрибут нигде не фигурирует, браузер использует его по умолчанию. Если задать <table cellspacing="0">, то получим не двойные, а одинарные линии, но удвоенной толщины. Для изменения указанной особенности применяется стилевое свойство border-collapse со значением collapse, которое добавляется к селектору TABLE (пример 4).

Пример 4. Создание одинарной рамки

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html>  <head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  <title>Таблицы</title>  <style type="text/css">  TABLE {  border-collapse: collapse; /* Убираем двойные границы между ячейками */  background: #dc0; /* Цвет фона таблицы */  border: 4px solid #000; /* Рамка вокруг таблицы */  }  TD, TH {  padding: 5px; /* Поля вокруг текста */  border: 2px solid green; /* Рамка вокруг ячеек */  }  </style>  </head>  <body>  <table>  <tr><th>Заголовок 1</th><th>Заголовок 2</th></tr>  <tr><td>Ячейка 3</td><td>Ячейка 4</td></tr>  </table>  </body> </html>

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

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

Граница вокруг таблицы

Рис. 4. Граница вокруг таблицы

При добавлении border-collapse: collapse значение атрибута cellspacing тега <table> игнорируется.

Выравнивание содержимого ячеек

По умолчанию текст в ячейке таблицы выравнивается по левому краю. Исключением из этого правила служит тег <th>, он определяет заголовок, в котором выравнивание происходит по центру. Чтобы изменить способ выравнивания применяется стилевое свойство text-align (пример 5).

Пример 5. Выравнивание содержимого ячеек по горизонтали

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html>  <head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  <title>Таблицы</title>  <style type="text/css">  TABLE {  border-collapse: collapse; /* Убираем двойные линии между ячейками */  width: 300px; /* Ширина таблицы */  }  TH {   background: #fc0; /* Цвет фона ячейки */  text-align: left; /* Выравнивание по левому краю */  }  TD {  background: #fff; /* Цвет фона ячеек */  text-align: center; /* Выравнивание по центру */  }  TH, TD {  border: 1px solid black; /* Параметры рамки */  padding: 4px; /* Поля вокруг текста */  }  </style>  </head>   <body>  <table>  <tr><th>Заголовок 1</th><td>Ячейка 1</td><td>Ячейка 2</td></tr>  <tr><th>Заголовок 2</th><td>Ячейка 3</td><td>Ячейка 4</td></tr>  </table>  </body> </html>

В данном примере содержимое тега <th> выравнивается по левому краю, а содержимое тега <td> — по центру. Результат примера показан ниже.

Выравнивание текста в ячейках

Рис. 5. Выравнивание текста в ячейках

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

Пример 6. Выравнивание содержимого ячеек по вертикали

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html>  <head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  <title>Таблицы</title>  <style type="text/css">  TABLE {  border-collapse: collapse; /* Убираем двойные линии между ячейками */  width: 300px; /* Ширина таблицы */  }  TH, TD {  border: 1px solid black; /* Параметры рамки */  text-align: center; /* Выравнивание по центру */  padding: 4px; /* Поля вокруг текста */  }  TH {  background: #fc0; /* Цвет фона ячейки */  height: 40px; /* Высота ячеек */  vertical-align: bottom; /* Выравнивание по нижнему краю */  padding: 0; /* Убираем поля вокруг текста */  }  </style>  </head>   <body>  <table>  <tr><th>Заголовок 1</th><th>Заголовок 2</th></tr>  <tr><td>Ячейка 1</td><td>Ячейка 2</td></tr>  </table>  </body> </html>

В данном примере устанавливается высота заголовка <th> как 40 пикселов и выравнивание текста происходит по нижнему краю. Результат примера показан на рис. 6.

Выравнивание текста в ячейках

Рис. 6. Выравнивание текста в ячейках

htmlbook.ru

Форматирование таблиц

  • Содержание:
  • 1. Границы таблицы border
  • 2. Как задать ширину и высоту таблицы
  • 3. Как задать фон таблицы
  • 4. Столбцы таблицы
  • 5. Как добавить таблице заголовок
  • 6. Как убрать промежуток между рамками ячеек
  • 7. Как увеличить промежуток между рамками ячеек
  • 8. Как скрыть пустые ячейки таблицы
  • 9. Компоновка макета таблицы с помощью свойства table-layout
  • 10. Лучшие макеты таблиц (Топ-10 таблиц)

1. Границы таблицы border

Таблица и ячейки внутри неё по-умолчанию отображаются в браузере без видимых границ. Границы таблицы задаются свойством border:

table {  border-collapse: collapse; /*убираем пустые промежутки между ячейками*/  border: 1px solid grey; /*устанавливаем для таблицы внешнюю границу серого цвета толщиной 1px*/  }

Границы ячеек заголовка каждого столбца задаются для элемента th:

th {border: 1px solid grey;}

Границы ячеек тела таблицы задаются для элемента td:

td {border: 1px solid grey;}

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

th, td {border: 1px solid grey;}

Внешнюю границу таблицы можно выделить, задав ей увеличенную ширину:

table {border: 3px solid grey;}

Границы можно задавать частично:

/* устанавливаем для таблицы внешнюю границу серого цвета толщиной 3px */  table {border-top: 3px solid grey; }  /* задаём для ячейки тела таблицы границу серого цвета толщиной 1px */  td {border-bottom: 1px solid grey;}

Подробнее о свойстве border вы можете прочитать здесь.

2. Как задать ширину и высоту таблицы

По умолчанию ширина и высота таблицы определяется содержимым её ячеек. Если ширина не задана, то она будет равна ширине самого широкого ряда (строки).

Ширина таблицы и столбцов задаётся с помощью свойства width. Если для таблицы задано table {width: 100%;}, то ширина таблицы будет равна ширине блока-контейнера, в котором она находится.

Ширину таблицы и столбцов обычно задают в px или %, например:

table {width: 600px;}  th {width: 20%;}  td:first-child {width: 30%;}

Высота таблицы не задается. Высотой рядов таблицы можно управлять, добавив верхний и нижний padding для элементов <td> и <th>. Фиксировать высоту с помощью свойства height не рекомендуется.

th, td {padding: 10px 15px;}

3. Как задать фон таблицы

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

4. Столбцы таблицы

Модель CSS таблиц ориентирована в основном на строки (ряды), формируемые с помощью тега <tr>. На практике бывают случаи, когда необходимо специальное форматирование столбцов, которое возможно следующими способами:

с помощью тега <col> можно задать фон для любого количества столбцов;

с помощью селектора table td:first-child, table td:last-child можно задать стили для первого или последнего столбца таблицы (за исключением первой ячейки заголовка таблицы);

с помощью селектора table td:nth-child(правило отбора столбцов) можно задать стили для любых столбцов таблицы.

Подробнее про тег <col> вы можете прочитать здесь.

Подробнее про CSS-селекторы вы сможете прочитать здесь.

5. Как добавить таблице заголовок

Добавить заголовок в таблицу можно с помощью тега <caption>, а с помощью свойства caption-side его можно поместить перед таблицей или под ней. Для горизонтального выравнивания текста заголовка применяется свойство text-align. Наследуется.

caption-side
Значения:
top Заголовок таблицы располагается над таблицей. Значение по умолчанию.
bottom Располагает заголовок под таблицей.
initial Устанавливает значение свойства в значение по умолчанию.
inherit Наследует значение свойства от родительского элемента.
<table>   <caption>Таблица № 1</caption>   <tr>   <th>Company</th>   <th>Q1</th>   <th>Q2</th>   <th>Q3</th>   <th>Q4</th>   </tr>  ...  </table>
caption {  caption-side: bottom;  text-align: right;  padding: 10px 0;   font-size: 14px;  }
caption_side
Рис. 2. Пример отображения заголовка под таблицей

6. Как убрать промежуток между рамками ячеек

Рамки ячеек таблицы по умолчанию разделены небольшим промежутком. Если задать для таблицы border-collapse: collapse, то промежуток уберётся. Свойство наследуется.

border-collapse
Значения:
separate Рамки ячеек располагаются раздельно.
collapse Рамки ячеек сливаются в одну, а промежутки между рамками убираются.
initial Устанавливает значение свойства в значение по умолчанию.
inherit Наследует значение свойства от родительского элемента.

Синтаксис

table {border-collapse: collapse;}
table_border_collapse
Рис. 3. Пример таблиц со сливающимися и раздельными рамками ячеек

7. Как увеличить промежуток между рамками ячеек

С помощью свойства border-spacing можно менять расстояние между рамками ячеек. Данное свойство применяется к таблице в целом. Наследуется.

border-spacing
Значения:
<длина> <длина> Добавляет промежутки между рамками как по вертикали, так и по горизонтали. Если заданы две длины, то первая всегда определяет горизонтальный промежуток, а вторая — вертикальный.
initial Устанавливает значение свойства в значение по умолчанию.
inherit Наследует значение свойства от родительского элемента.

Синтаксис

table {border-collapse: separate; border-spacing: 10px 20px;}  table {border-collapse: separate; border-spacing: 10px;}
table_border_spacing
Рис. 4. Пример таблиц с увеличенными промежутками между рамками ячеек

8. Как скрыть пустые ячейки таблицы

Свойство empty-cells скрывает или показывает пустые ячейки. Действует только на ячейки, которые не содержат какой-либо контент. Если для ячейки задан фон, а для таблицы задано table {border-collapse: collapse;}, то ячейка не будет скрыта. Наследуется.

empty-cells
Значения:
show Рамка и фон пустой ячейки будут отрисовываться так же, как для ячейки таблицы, имеющей содержимое.
hide Если все ячейки строки пусты, то вся строка отображается так, если бы было задано значение display: none.
initial Устанавливает значение свойства в значение по умолчанию.
inherit Наследует значение свойства от родительского элемента.
<table>  <tr>   <th>Company</th>   <th>Q1</th>   <th>Q2</th>   <th>Q3</th>   </tr>  <tr>   <td>Microsoft</td>   <td>20.3</td>   <td>30.5</td>   <td></td>  </tr>  <tr>   <td>Google</td>   <td>50.2</td>   <td>40.63</td>   <td>45.23</td>  </tr>  </table>
table {  border: 1px solid #69c;  border-collapse: separate;  empty-cells: hide;  }  th, td {border: 2px solid #69c;}
table_empty
Рис. 5. Пример скрытия пустой ячейки таблицы

9. Компоновка макета таблицы с помощью свойства table-layout

Компоновка макета таблицы определяется одним из двух подходов: фиксированный макет или автоматический макет. Под компоновкой в данном случае подразумевается как распределяется ширина таблицы между шириной ячеек. Свойство не наследуется.

table-layout
Значения:
auto Значение по умолчанию. Ширина макета таблицы определяется шириной её содержимого с учетом значений свойств padding-left, padding-right, border-left width плюс одна ширина border-right последней ячейки в ряду, или заданной шириной ячеек и толщиной рамки. Если ширина ячеек не задана явно, они могут быть разной ширины.
fixed Свойство сработает только в том случае, если для таблицы задана ширина. Ширина ячеек будет одинаковой, а содержимое ячеек, которое не помещается в ячейку, будет наползать под содержимое соседней ячейки.
initial Устанавливает значение свойства в значение по умолчанию.
inherit Наследует значение свойства от родительского элемента.

Синтаксис

table {table-layout: fixed;}

10. Лучшие макеты таблиц

(По материалам статьи Top 10 CSS Table Designs из журнала Smashing Magazine)

top-table

Перейти на страницу с примерами

1. Горизонтальный минимализм

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

<table>  <tr><th>Employee</th><th>Salary</th><th>Bonus</th><th>Supervisor</th></tr>  <tr><td>Stephen C. Cox</td><td>$300</td><td>$50</td><td>Bob</td></tr>  <tr><td>Josephin Tan</td><td>$150</td><td>-</td><td>Annie</td></tr>  <tr><td>Joyce Ming</td><td>$200</td><td>$35</td><td>Andy</td></tr>  <tr><td>James A. Pentel</td><td>$175</td><td>$25</td><td>Annie</td></tr>  </table>
table {   font-family: "Lucida Sans Unicode", "Lucida Grande", Sans-Serif;   font-size: 14px;   background: white;   max-width: 70%;   width: 70%;   border-collapse: collapse;   text-align: left;  }  th {   font-weight: normal;   color: #039;   border-bottom: 2px solid #6678b1;   padding: 10px 8px;  }  td {   color: #669;   padding: 9px 8px;   transition: .3s linear;  }  tr:hover td {color: #6699ff;}

При большом количестве строк такой дизайн таблиц затрудняет их чтение. Для решения этой проблемы можно добавить однопиксельную границу под всеми элементами td.
top-table2

td {   border-bottom: 1px solid #ccc;   color: #669;   padding: 9px 8px;   transition: .3s linear;  }/*остальной код - как в примере выше*/

Добавление эффекта :hover для элемента tr облегчит чтение таблиц, оформленных в минималистском стиле. При наведении курсора мыши на ячейку, остальные ячейки той же строки выделяются одновременно, что упрощает процесс отслеживания информации, если таблицы имеют несколько столбцов.
top-table3

th {   font-weight: normal;   color: #039;   padding: 10px 15px;  }  td {   color: #669;   border-top: 1px solid #e8edff;   padding: 10px 15px;  }  tr:hover td {background: #e8edff;}

2. Вертикальный минимализм

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

th {   font-weight: normal;   border-bottom: 2px solid #6678b1;   border-right: 30px solid #fff;   border-left: 30px solid #fff;   color: #039;   padding: 8px 2px;  }  td {   border-right: 30px solid #fff;   border-left: 30px solid #fff;   color: #669;   padding: 12px 2px;  }

3. «Коробочный» стиль

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

th {   font-size: 13px;   font-weight: normal;   background: #b9c9fe;   border-top: 4px solid #aabcfe;   border-bottom: 1px solid #fff;   color: #039;   padding: 8px;  }  td {   background: #e8edff;   border-bottom: 1px solid #fff;   color: #669;   border-top: 1px solid transparent;   padding: 8px;  }  tr:hover td {background: #ccddff;}

Самое сложное — найти ту цветовую гамму, которая будет гармонично сочетаться с вашим сайтом. Если сайт нагружен по графике и дизайну, то вам будет довольно трудно использовать этот стиль.
top-table6

table {   font-family: "Lucida Sans Unicode", "Lucida Grande", Sans-Serif;   font-size: 14px;   max-width: 70%;   width: 70%;   text-align: center;   border-collapse: collapse;   border-top: 7px solid #9baff1;   border-bottom: 7px solid #9baff1;  }  th {   font-size: 13px;   font-weight: normal;   background: #e8edff;   border-right: 1px solid #9baff1;   border-left: 1px solid #9baff1;   color: #039;   padding: 8px;  }  td {   background: #e8edff;   border-right: 1px solid #aabcfe;   border-left: 1px solid #aabcfe;   color: #669;   padding: 8px;  }

4. Горизонтальная зебра

Зебра-таблица выглядит довольно привлекательной и удобной. Дополнительный цвет фона может служить в качестве визуальной подсказки для людей при чтении таблицы.
top-table7

th {   font-weight: normal;   color: #039;   padding: 10px 15px;  }  td {   color: #669;   border-top: 1px solid #e8edff;   padding: 10px 15px;  }  tr:nth-child(2n) {background: #e8edff;}

5. Газетный стиль

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

table {border: 1px solid #69c;}  th {   font-weight: normal;   color: #039;   border-bottom: 1px dashed #69c;   padding: 12px 17px;  }  td {   color: #669;   padding: 7px 17px;  }  tr:hover td {background: #ccddff;}

top-table9

table {border: 1px solid #69c;}  th {   font-weight: normal;   color: #039;   padding: 10px;  }  td {   color: #669;   border-top: 1px dashed #fff;   padding: 10px;   background:#ccddff;  }  tr:hover td {background: #99bcff;}

top-table10

table {border: 1px solid #6cf;}  th {   font-weight: normal;   font-size: 13px;   color: #039;   text-transform: uppercase;   border-right: 1px solid #0865c2;   border-top: 1px solid #0865c2;   border-left: 1px solid #0865c2;   border-bottom: 1px solid #fff;   padding: 20px;  }  td {   color: #669;   border-right: 1px dashed #6cf;   padding: 10px 20px;  }

html5book.ru


You May Also Like

About the Author: admind

Добавить комментарий

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

Этот сайт использует Akismet для борьбы со спамом. Узнайте как обрабатываются ваши данные комментариев.

Adblock
detector