htmlbook.ru - Для тех, кто делает сайты
Статьи Книги Шаг за шагом Рецепты Форум Графика для Web
Главная страница > Статьи > Оформление таблиц > Колонки таблицы

Колонки таблицы

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

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

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

Поскольку формирование таблицы происходит по строкам, а не по колонкам, то для изменения вида колонок приходится задавать стиль практически для каждой ячейки. В этом случае удобно использовать разные классы — один для ячеек четных колонок, а второй — для нечетных. На рис. 1 показана таблица, которая формируется именно таким способом.

Рис. 1. Таблица с выделенными колонками

Рис. 1. Таблица с выделенными колонками

Цвет нечетных колонок можно задать путем добавления стилевых параметров к селектору TABLE, а для четных колонок введем новый класс, назовем его even. Первая колонка обычно используется для заголовков строк, поэтому для нее имеет смысл задать стиль, отличный от стиля остальных ячеек. В данном случае вводим еще один класс, назовем его lc и для него определим выравнивание по левому краю и цвет текста (пример 1). Остается для ячеек первой колонки добавить к тегу <TD> параметр class="lc", а для ячеек четных колонок class="even".

Пример 1. Колонки разного цвета

Валидный HTML
Валидный CSS
<!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=windows-1251">
<title>Таблица</title>
<style type="text/css">
TABLE {
 width: 300px; /* Ширина таблицы */
 border: 2px solid black; /* Рамка вокруг таблицы */
 background: #778899; /* Цвет фона */
 color: white; /* Цвет текста */
}

TD, TH {
 text-align: center; /* Выравнивание по центру */
 padding: 3px; /* Поля вокруг текста */
}

TH {
 color: white; /* Цвет текста */
 border-bottom: 4px double black; /* Двойная линия снизу */
}

.even { /* Стиль для четных колонок */
 background: #ffe4b5; /* Цвет фона */
 color: black; /* Цвет текста */
}

.lc { /* Стиль для первой колонки */
 text-align: left; /* Выравнивание по левому краю */
 color: #fffacd; /* Цвет текста */
}
</style>
</head>
<body>

<table cellspacing="0">
 <tr>
  <th>&nbsp;</th>
  <th class="even">2004</th>
  <th>2005</th>
  <th class="even">2006</th>
 </tr>
 <tr>
  <td class="lc">Рубины</td>
  <td class="even">43</td>
  <td>51</td>
  <td class="even">79</td>
 </tr>
 <tr>
  <td class="lc">Изумруды</td>
  <td class="even">28</td>
  <td>34</td>
  <td class="even">48</td>
 </tr>
 <tr>
  <td class="lc">Сапфиры</td>
  <td class="even">29</td>
  <td>57</td>
  <td class="even">36</td>
 </tr>
</table>

</body>
</html>

Чтобы отделить первую строку с заголовком от данных таблицы в примере используется двойная линия. Она получается за счет добавления параметра border-bottom к селектору TH.

Рассмотрим еще один способ формирования вида колонок — не только за счет разного цвета фона, но и применением линий между колонками (рис. 2).

Рис. 2. Выделение колонок с помощью линий и цвета

Рис. 2. Выделение колонок с помощью линий и цвета

Структура кода останется практически той же, что была показана в примере 1. А именно, для ячеек четных колонок используем класс even, а для первой колонки — класс lc. Чтобы установить линию между колонками, к селектору TD добавляем параметр border-left, он создает линию слева от ячейки. Однако при этом возникнет ненужная линия слева в первой колонке, поэтому для класса lc используем border: none, этот атрибут уберет лишние границы (пример 2).

Пример 2. Линии между колонками

Валидный HTML
Валидный CSS
<!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=windows-1251">
<title>Таблица</title>
<style type="text/css">
TABLE {
 width: 300px; /* Ширина таблицы */
 border: 1px solid black; /* Рамка вокруг таблицы */
}

TD, TH {
 text-align: center; /* Выравнивание по центру */
 padding: 3px; /* Поля вокруг текста */
}

TH {
 color: white; /* Цвет текста */
 background: #daa520; /* Цвет фона */
}

TD {
 border-left: 1px dashed black; /* Линия слева от ячейки */
}

.even { /* Стиль для четных колонок */
 background: #dcdcdc; /* Цвет фона */
}

.lc { /* Стиль для первой колонки */
 text-align: left; /* Выравнивание по левому краю */
 border: none; /* Нет лишних линий */
}
</style>
</head>
<body>

<table cellspacing="0">
 <tr>
  <th>&nbsp;</th>
  <th>2004</th>
  <th>2005</th>
  <th>2006</th>
 </tr>
 <tr>
  <td class="lc">Рубины</td>
  <td class="even">43</td>
  <td>51</td>
  <td class="even">79</td>
 </tr>
 <tr>
  <td class="lc">Изумруды</td>
  <td class="even">28</td>
  <td>34</td>
  <td class="even">48</td>
 </tr>
 <tr>
  <td class="lc">Сапфиры</td>
  <td class="even">29</td>
  <td>57</td>
  <td class="even">36</td>
 </tr>
</table>

</body>
</html>

К сожалению, работа с колонками таблицы не так удобна, как хотелось бы. Если применять стили, то фактически все ячейки таблицы пестрят указаниями на определенный стилевой класс. За счет этого снижается удобство по расширению табличных данных и повышается объем кода. Существуют специальные теги <COL> и <COLGROUP> призванные облегчить работу с колонками таблицы. Но их возможности ограничены, да и нужный результат будет отображаться не во всех браузерах. Так что на данном этапе для создания таблиц желаемого вида приходится обращаться к стилям.

Статья опубликована: 15.10.2005 Последнее обновление: 20.04.2008

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

  1. Не задавайте вопросы в комментариях, для этой цели предназначен форум, где вы получите нужную помощь.
  2. Удаляются любые комментарии, которые:
    • включают множество ошибок;
    • написаны безграмотно;
    • не имеют отношения к данной статье;
    • не содержат никакой полезной информации для посетителей.
  3. Для выделения отдельных слов используйте следующие команды: [b]жирный[/b], [i]курсив[/i], [color=цвет]цветной текст[/color], [tag]тег[/tag], [var]параметр[/var], [code]пример[/code].
  4. Потренироваться в написании комментариев вы можете в песочнице.

Комментарии к статье

austere

03.09.2006

В IE для многое можно задать с помощью <col> - основные параметры, такие как цвет фона, шрифт, text-align наследуются <td> от <col>.
Я для других браузеров использовать соседние селекторы:
TABLE.abc TD:first-child + TD + ... {...}

Алексей

27.02.2008

Как задать цвет шрифта для одного столбца красный, а для второго синий?
Если применять через css, тo значение font-color применяется только к &lt;TH&gt;

Lumos

01.03.2008

font-color? ?? э... а не color ли?

Алексей

04.03.2008

Да сорри ошибся, не font-color, а просто color. Но один хрен в опере не наследует тег <td> от тега <col>
Так что пришлось на сайте пока что написать (как не прискорбно конечно), что сайт заточен под Iexplorer (((

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

Имя
Комментарий

Сохранить имя (используется cookie)

Поиск по сайту

Оформление таблиц
Разделы
Теги по теме

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

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

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

CSS по теме

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

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

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

color
Определяет цвет текста элемента.

text-align
Определяет горизонтальное выравнивание текста в пределах элемента.

width
Устанавливает ширину блочных или заменяемых элементов. Ширина не включает толщину границ вокруг элемента, значение отступов и полей.

Copyright 2002–2008 Влад Мержевич, по всем вопросам пишите по адресу: vlad@htmlbook.ru

О сайте | Планы на будущее | Использование сайта | Борьба с ошибками | Технологии | Поддержать проект