Help:Tables/ru


 * Чтобы узнать о структуре таблиц базы данных MediaWiki, см. 

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

Вики-разметка таблиц

 * вышеприведённые знаки должны начинаться с новой строки, кроме двойных  и   для последовательных ячеек в строке. Тем не менее, пробелы в начале строки игнорируются.
 * атрибуты XHTML. Каждый знак разметки, кроме конца таблицы, может иметь при себе один или несколько атрибутов XHTML. Атрибуты должны быть на той же строке, что и знаки разметки. Атрибуты следует разделять друг от друга одиночным пробелом.
 * У ячеек и заголовка ( или ,   или  , и  ) есть содержимое. Поэтому содержимое от атрибутов тэга нужно отделять вертикальной чертой . Содержимое может располагаться в той же строке или в следующих строках.
 * Маркеры таблицы и строк ( и  ) напрямую не содержат контента. Не добавляйте разделитель в виде вертикальной черты  после их необязательных атрибутов. Если вы добавите его по ошибке к маркеру таблицы или строки, парсер удалит его и атрибут может присоединиться к неверному маркеру.
 * Содержимое может располагаться (а) за знаком ячейки в той же строке после необязательных XHTML атрибутов или (б) на строках под знаком ячейки. Содержимое, использующее вики-разметку, которая должна сама начинаться с новой строки, например, списки, заголовки или вложенные таблицы, разумеется, должно начинаться с новой строки.
 * Вертикальная черта в качестве символа. Для того, чтобы вставить вертикальную черту в качестве символа в таблицу, используйте экранирование &lt;nowiki&gt; &lt;/nowiki&gt;.

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

{| style="width:100%" ! style="width: 50%;"|Вы вводите ! style="width: 50%;"|Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Ячейки в одной строке могут быть размещены на одной линии, разделённые знаками  (два символа-разделителя). Если текст в ячейке должен содержать разрыв строки, используйте вместо разрыва.

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

У вас также может быть более длинный текст или более сложное написание в ячейках таблицы:

{| style="width:100%" ! style="width: 50%;"|Вы вводите ! style="width: 50%;"|Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

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

{| style="width:100%" ! style="width: 50%;"|Вы вводите ! style="width: 50%;"|Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Замечание: При использовании атрибутов, как в заголовке 'Предмет', нужна вертикальная черта '|' для разделения. Но не восклицательный знак '!'.

Название таблицы
Над таблицей может быть размещено её название, как показано ниже.

class="wikitable"
Основной стиль (светло-серый фон, границы, отступ и выравнивание слева) можно получить, добавив class="wikitable".

Атрибуты HTML colspan и rowspan
Вы можете использовать атрибуты HTML colspan и rowspan для ячеек при более сложной разметке.

{| style="width:100%" ! style="width: 50%;"|Вы вводите ! style="width: 50%;"|Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Атрибуты XHTML
В таблицы вы можете добавлять атрибуты XHTML. В качестве официального источника по ним см., страницу спецификации W3C HTML-таблиц.

Атрибуты для таблиц
Помещая атрибуты после начального тэга таблицы применяет атрибуты ко всей таблице.

{| style="width:100%" ! style="width: 50%;"| Вы вводите ! style="width: 50%;"| Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

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

Также можно использовать атрибуты ячейки, когда вы размещаете несколько ячеек в одной строке. Обратите внимание, что ячейки разделены, а внутри каждой ячейки атрибут(ы) и значение разделены.

{| style="width:100%" ! style="width: 50%;"| Вы вводите ! style="width: 50%;"| Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Атрибуты для строк
Для строки тоже можно использовать атрибуты.

{| style="width:100%" ! style="width: 50%;"|Вы вводите ! style="width: 50%;"|Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Простая граница таблицы в 1 пиксель
Пример однопиксельной табличной границы:

{| style="width:100%" ! style="width:50%" | Вы вводите ! style="width:50%" | Вы получаете
 * style="padding: 5px;" |
 * style="padding: 5px;" |
 * style="padding: 20px;"|


 * }

Ширина границы
Если у атрибута "border-width:" только одно число, он применяется ко всем четырем сторонам границы: {| style="width:100%" ! style="width:50%" | Вы вводите ! style="width:50%" | Вы получаете
 * style="padding: 5px;" |
 * style="padding: 5px;" |
 * style="padding: 20px;"|


 * }

Если у атрибута "border-width:" более одного числа, четыре цифры соответствуют сверху, справа, снизу, снизу (ЗАПОМНИТЕ этот порядок):

{| style="width:100%" ! style="width:50%" | Вы вводите ! style="width:50%" | Вы получаете
 * style="padding: 5px;" |
 * style="padding: 5px;" |
 * style="padding: 20px;"|


 * }


 * Когда значений меньше 4х, то значение для левой границы соответствует значению для правой, значение для нижней границы соответствует значению для верхней, а значение для правой границы соответствует значению для верхней.

Другой метод задать ширину четырёх сторон ячейки - использовать атрибуты "border-left", "border-right", "border-top" и "border-bottom": {| style="width:100%" ! style="width:50%" | Вы вводите ! style="width:50%" | Вы получаете
 * style="padding: 5px;" |
 * style="padding: 5px;" |
 * style="padding: 20px;"|


 * }

Свойства стиля CSS (которые отменяет действия атрибутов HTML) требуют явную единицу длины (если значение не равно нулю), например "px" для пикселя.
 * HTML атрибуты (такие как "width=", "border=", "cellspacing=", "cellpadding=") не нуждаются в единицах длины (здесь предполагаются пиксели). Они также недействительны в HTML 5.

С HTML атрибутами и стилями CSS
Атрибуты стиля CSS можно использовать вместе с другими HTML атрибутами или отдельно.

Атрибуты
Атрибуты можно добавлять в заголовки и названия как показано ниже.

{| style="width:100%" ! style="width: 50%;"|Вы вводите ! style="width: 50%;"|Вы получаете
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Ширина столбца
Ширину столбца можно задать следующим образом:

Вы вводите:

Вы получаете:

Accessibility of table header cells
Table header cells do not explicitly specify which table data cells they apply to (those on their right on the same row, or those below them on the same column). When the table is rendered in a visual 2D environment, this is usually easy to infer.

However when tables are rendered on non-visual media, you can help the browser to determine which table header cell applies to the description of any selected cell (in order to repeat its content in some accessibility helper) using a scope="row" or scope="col" attribute on table header cells. In most cases with simple tables, you'll use scope="col" on all header cells of the first row, and scope="row" on the first cell of the following rows:

{| style="width:100%" ! style="width: 50%;"|Вы пишете ! style="width: 50%;"|Вы видите
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Table alignment
Table alignment is achieved by using CSS. The table alignment is controlled by margins. A fixed margin on one side will make the table to be aligned to that side, if on the opposite side the margin is defined as auto. To have a table center aligned, you should set both margins to auto

For example, a right-aligned table:

{| style="width:100%" ! style="width: 50%;"|Вы пишете ! style="width: 50%;"|Вы видите
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

And a center-aligned table:

{| style="width:100%" ! style="width: 50%;"|Вы пишете ! style="width: 50%;"|Вы видите
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Table floating around text
If you align a table to the right or the left side of the page, the text that comes after the table starts at the end of it, leaving an empty space around the table. You can make the text to be wrapped around the table by making the table to float around the text instead of just aligning it. This can be achieved using the  CSS attribute, which can specify where the table floats to the right side or to the left. When using float, margins doesn't control table alignment and can be used to specify the margin between the table and the surrounding text.

{| style="width:100%" ! style="width: 50%;"|Вы пишете ! style="width: 50%;"|Вы видите
 * style="padding: 5px;"|
 * style="padding: 5px;"|

Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.
 * style="padding: 5px;"|

Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.
 * }

Cell contents alignment
The alignment of cell contents can be controlled with 2 different CSS properties:  and. can be specified at the table, row or individual cells, while  only can be specified at individual rows or cells.

{| style="width:100%" ! style="width: 50%;"|Вы пишете ! style="width: 50%;"|Вы видите
 * style="padding: 5px;"|
 * style="padding: 5px;"|
 * style="padding: 5px;"|


 * }

Отрицательные числа
Отрицательные числа или знак минус (обозначающий отсутствие какого-либо значения) может нарушить таблицу, если ячейка начинается с новой строки (|-6), потому что это воспринимается вики как начало новой строки в таблице, а не новой ячейки. Чтобы избежать такой проблемы, ставьте пробел перед минусом (| -6) или воспользуйтесь внутристроковой разметкой (||-6).

CSS vs attributes
Table borders specified through CSS rather than the border attribute will render incorrectly in a small subset of text browsers.

Common attributes for columns, column groups and row groups
The MediaWiki syntax for tables currently offers no support for specifying common attributes for columns (with the HTML element ), column groups (HTML element  ) and row groups (HTML elements ,  ). Those standard HTML elements are not accepted even in their HTML or XHTML syntax.

All the rows and cells (header or data) of the table are rendered within a single implicit row group (HTML element ) without any attributes or styles.

См. также

 * Sorting rows of a table
 * Easy tool that helps generating tables
 * . Good for country lists in table format.
 * Easy tool that helps generating tables
 * . Good for country lists in table format.