Разметка Web-страниц
с помощью таблиц
- В коде HTML каждая строка и ячейка таблицы создается индивидуально.
- До начала создания таблицы ее надо обязательно нарисовать, подсчитать количество строк и ячеек, определить, какие ячейки надо объединить.
Дескрипторы создания таблицы:
<Table> … </Table>
- <TR> …</TR> - новая строка
- <TH> … </TH> - ячейка заголовка
- <TD> … </TD> - обычная ячейка
- По умолчанию текст в ячейках заголовка показан полужирным шрифтом с выравниванием по центру
- Текст в обычных ячейках не выделяется и выравнивается по левому краю
Пример простейшей пустой таблицы
Создание таблицы с различным
числом ячеек в строках
Добавление заголовка таблицы
- Заголовок таблицы можно создать с помощью известных вам дескрипторов <Н1>—<Н6>
- Но поскольку ширина таблицы может отличаться от ширины окна обозревателя, выровнять текстовый заголовок относительно таблицы может оказаться довольно сложно.
Поэтому для создания заголовков лучше использовать дескриптор <CAPTION>, который создает заголовок непосредственно в таблице.
- По умолчанию заголовок выравнивается по центру таблицы.
- Чтобы изменить выравнивание влево или вправо, присвойте атрибуту ALIGN в дескрипторе <CAPTION> значение left или right.
- Атрибуту ALIGN также можно присвоить значение bottom. В этом случае заголовок появится под таблицей.
- В принципе в таблице допускается создание нескольких заголовков, но лучше этого не делать. Так, в обозревателе Netscape Navigator дескриптор <caption> может произвольно изменить порядок заголовков.
Заливка ячеек цветом
- Для установки цвета ячейки таблицы применяется атрибут BGCOLOR. Окрашивание ячеек используется для выделения важных блоков данных в таблице.
- Чтобы установить цвет фона сразу для группы ячеек, выполните группировку столбцов или строк.
Использование в таблице фоновых
изображений
- Фоновый рисунок устанавливается в атрибуте BACKGROUND.
- Этот атрибут можно установить как для всей таблицы в дескрипторе <TABLE>, так и для отдельной ячейки в дескрипторах <td> и <тн>. Соответственно, если в первом случае рисунок будет помещен в фоне всей таблицы, то во втором случае — только в фоне данной ячейки. Если разные фоновые рисунки были назначены таблице и ячейке, то фоновый рисунок ячейки появится поверх рисунка таблицы.
- Требования к фоновым рисункам таблицы такие же, как и к фону Web-страницы, — фон не должен мешать чтению текста и восприятию информации.
Однако!
- Следует учесть, что разные обозреватели по-разному отображают фоновые рисунки, назначенные всей таблице.
Если Internet Explorer заполняет копиями изображения все пространство таблицы, так же, как фоновый рисунок страницы заполняет все окно обозревателя, то Netscape Navigator повторит рисунок в каждой ячейке.
В связи с этим лучше воздержаться от использования фоновых рисунков таблицы.
Разметка макета страницы с
помощью таблицы, содержащей фоновые
рисунки
- Размеры ячеек устанавливаются с помощью атрибутов width и height и две ячейки в первом столбце объединяются с помощью атрибута ROWSPAN.
- Обратите внимание на следующий важный момент: в дескрипторе <table> атрибутам
border, cellpadding и CELLSPACING
присвоено значение 0.
Благодаря этому не видны границы между фоновыми рисунками в ячейках и выравнивание текста заголовка в верхней панели совпадает с выравниванием фонового рисунка.
Прорисовка границ таблицы
- По умолчанию обозреватели не показывают границы вокруг таблицы и между ячейками. Это вполне подходит, если таблица используется для разметки макета документа. Если же нужно представить данные в форме таблицы, то прорисовка границ усилит зрительный эффект и поможет пользователям лучше понять взаимосвязи данных в ячейках таблицы.
Границы таблицы
- с помощью атрибута BORDER в дескрипторе <TABLE> мы устанавливаем показ границ таблицы.
Данному атрибуту присваивается значение ширины внешней границы таблицы в пикселях.
- Обратите внимание, что атрибут BORDER изменяет вид только внешней границы вокруг таблицы, тогда как внутренние границы между ячейками не меняются.
- Для изменения внутренних границ используются атрибуты CELLPADDING и CELLSPACING.
- По умолчанию обозреватели показывают границы серым цветом. Чтобы изменить цвет, воспользуйтесь атрибутом BORDERCOLOR.
- Установка данного атрибута изменит цвет как внешних, так и внутренних границ. При этом исчезнет эффект объемности границ
- Чтобы убрать границы, присвойте атрибуту BORDER значение 0, или просто удалите этот атрибут из дескриптора <TABLE>.
Выборочная прорисовка границ
- Установив атрибут BORDER, можно либо показать все границы, либо не показывать границ.
- Однако, часто нужно показать только внешние или только внутренние границы, но лишь вокруг определенных ячеек.
- Для выборочной прорисовки границ используются атрибуты FRAME и RULES в дескрипторе <TABLE>
Выборочная прорисовка границ
<table frame=‘hsides’ rules=‘cols’>
♦ FRAME — устанавливает
показ внешних границ таблицы:
- void — нет внешних границ;
- above — граница по верхнему краю таблицы;
- below — граница по нижнему краю таблицы;
- rhs — граница по правому краю таблицы;
- lhs — граница по левому краю таблицы; •
- hsides — границы по верхнему и нижнему краям таблицы;
- vsides — границы по левому и правому краям таблицы;
- border — все границы (задано по умолчанию).
♦ RULES — устанавливает
показ внутренних границ таблицы:
- none — нет внутренних границ;
- cols — границы между столбцами;
- rows — границы между строками;
- groups — границы между группами столбцов и строк;
- all — все внутренние границы (задано по умолчанию).
Группирование и объединение
ячеек таблицы
- Существует ряд дескрипторов кода HTML, которые предназначены для группирования ячеек таблицы. Это удобная функция, позволяющая форматировать группы ячеек как одно целое, вместо того чтобы устанавливать атрибуты в дескрипторе каждой индивидуальной ячейки.
- Установки атрибутов форматирования в индивидуальных ячейках имеют более высокий приоритет и отменяют установки для всей группы.
- Кроме того, можно объединить несколько ячеек в одну ячейку, которая будет занимать несколько столбцов или строк.
Объединение ячеек
- Иногда бывает необходимо создать в таблице ячейку, занимающую несколько столбцов или строк. Это особенно важно при выполнении разметки макета страницы с помощью таблицы.
- Для объединения ячеек в дескрипторах <TD> и <ТН> устанавливаются следующие параметры:
COLSPAN - число столбцов, занятых ячейкой;
ROWSPAN — число строк, занятых ячейкой.
Группирование столбцов
- Для группирования столбцов используются следующие дескрипторы:
♦ < COLGROUP > - структурная группа
столбцов, применяется для разбивки
таблицы на столбцы разных
типов, например: столбец заголовков
и столбцы данных;
♦ <COL> — неструктурная группа
столбцов, применяется для произвольного
группирования столбцов таблицы,
имеющих общий формат данных.
- Дескрипторы <C0LGROUP> И <COL> содержат набор атрибутов форматирования ячеек. Так, установка атрибута BGCOLOR в дескрипторе группы столбцов изменит цвет фона во всех ячейках, относящихся к группе.
Группирование столбцов для
форматирования таблицы
Создание вложенных таблиц
- Применение таблицы для разметки документов совершенно не мешает использованию таблиц в тексте этого же документа.
- Код HTML допускает создание вложенных таблиц. Для этого просто в ячейку таблицы добавьте новую таблицу
Выравнивание вложенной таблицы в ячейке определяется значением атрибута align в дескрипторе <table>.
Выравнивание таблиц в тексте
документа
- Выравнивание таблицы в тексте документа осуществляется с помощью атрибута ALIGN. Этому атрибуту присваиваются следующие значения:
left — таблица выравнивается
по левому краю окна с обтеканием текста
справа от таблицы;
right — таблица выравнивается
по правому краю окна с обтеканием текста
слева от таблицы;
all — таблица выравнивается
по центру окна с обтеканием текста справа
и слева от таблицы (поддерживается не
всеми обозревателями);
center — таблица выравнивается
по центру окна, разрывая текст на блоки
над и под таблицей.
- Чтобы выровнять фрагмент текста слева или справа от таблицы, а остальной текст продолжить ниже таблицы, введите дескриптор <BR> с установленным атрибутом CLEAR:
<BR CLEAR='left'>
- Атрибуту clear присваивается значение left или right, такое же, какое было присвоено атрибуту align таблицы.
Выравнивание рисунка в ячейке
таблицы