284 lines
7.3 KiB

4 years ago
////
Included in:
- user-manual: tables: columns
////
[#cols]
=== Columns
The number of columns in a table is determined by the number of cells found in the first non-blank line after the table delimiter (`|===`) or by the values assigned to the `cols` attribute.
For example, the syntax in the two examples below will both converted to a table with two columns.
[source]
----
include::ex-table.adoc[tag=2col-alt]
----
.Result: Rendered table with two columns as defined by the number of cells in the first row
[width="90"]
include::ex-table.adoc[tag=2col-alt]
[source]
----
include::ex-table.adoc[tag=2col]
----
.Result: Rendered table with two columns as defined by the `cols` attribute
[width="90"]
include::ex-table.adoc[tag=2col]
When a single number is assigned to the cols attribute, its value indicates the number of columns.
Each column will be the same width.
However, the number of columns can also be assigned as a comma delimited list.
The number of entries in the list determines the number of columns.
The comma delimited list below creates a table with four columns of equal width.
[source]
----
[cols="1,1,1,1"]
----
This syntax provides that same result:
[source]
----
[cols="4*"]
----
Now, let's talk about that asterisk in the syntax above.
[#cols-format]
=== Column Formatting
The AsciiDoc syntax provides a variety of ways to control the size, style and layout of content within columns.
These *specifiers* can be applied to whole columns.
To apply a specifier to a column, you must set the `cols` attribute and assign it a value.
A column specifier can contain any of the following components:
* multiplier
* align
* width
* style
Each component is optional.
The multiplier operator (`+*+`) is used when you want a specifier to apply to more than one consecutive column.
If used, the multiplier must always be placed at the beginning of the specifier.
For example:
[source]
----
include::ex-table.adoc[tag=indv-co]
----
<1> The table will consist of three columns, as indicated by the *3*. The `+*+` operator ensures that the default layout and style will be applied to all of the columns.
.Result: Rendered table with multiplier applied
[width="90"]
include::ex-table.adoc[tag=indv]
[#cols-align]
The alignment component allows you to horizontally or vertically align a column's content.
Content can be horizontally aligned left (`<`), center (`+^+`), or right (`>`).
To horizontally center the content in all of the columns, add the `+^+` operator after the multiplier.
[source]
----
[cols="3*^"]
include::ex-table.adoc[tag=base]
----
.Result: Rendered table with horizontal, center alignment applied to all columns
[width="90"]
[cols="3*^"]
include::ex-table.adoc[tag=base]
What if you only want to center the content in the last column?
Assign the default styles to the preceding columns, and `+^+` to the last column in a comma separated list.
[source]
----
[cols="2*,^"]
include::ex-table.adoc[tag=base]
----
.Result: Rendered table with horizontal, center alignment applied to last column
[width="90"]
[cols="2*,^"]
include::ex-table.adoc[tag=base]
Let's specify a different horizontal alignment for each column.
[source]
----
[cols="<,^,>"]
include::ex-table.adoc[tag=base]
----
.Result: Rendered table with a different horizontal alignment for each column
[width="90"]
[cols="<,^,>"]
include::ex-table.adoc[tag=base]
You'll notice that the content in the examples above is only centered on the horizontal.
It can also be aligned vertically when the alignment operator is prefixed with a dot (`.`).
Content can be vertically aligned to the top (`<`), middle (`+^+`), or bottom (`>`) of a cell.
To vertically align the content to the middle of the cells in all of the columns, add a `.` and then the `+^+` operator after the multiplier.
[source]
----
[cols="3*.^"]
include::ex-table.adoc[tag=base]
----
.Result: Rendered table with vertical, middle alignment applied to all columns
[width="90"]
[cols="3*.^"]
include::ex-table.adoc[tag=base]
If you only want to align the content to the bottom of each cell in the last column, you'd assign the default styles to the preceding columns, and `>` to the last column in a comma separated list.
[source]
----
[cols="2*,.>"]
include::ex-table.adoc[tag=base]
----
.Result: Rendered table with vertical, bottom alignment applied to last column
[width="90"]
[cols="2*,.>"]
include::ex-table.adoc[tag=base]
Let's specify a different vertical alignment for each column.
[source]
----
[cols=".<,.^,.>"]
include::ex-table.adoc[tag=base]
----
.Result: Rendered table with a different vertical alignment for each column
[width="90"]
[cols=".<,.^,.>"]
include::ex-table.adoc[tag=base]
Finally, we'll also horizontally center the content in the last column.
[source]
----
[cols=".<,.^,^.>"]
include::ex-table.adoc[tag=base]
----
.Result: Rendered table with a different vertical alignment for each column and horizontal, center alignment in the last column
[width="90"]
[cols=".<,.^,^.>"]
include::ex-table.adoc[tag=base]
When both a horizontal and vertical alignment is assigned to a column, the horizontal alignment operator must precede the vertical operator.
The width component sets the width of a column.
Its value can be a proportional integer (the default is 1) or a percentage (1 to 99).
[source]
----
[cols="1,2,6"]
include::ex-table.adoc[tag=base]
----
.Result: Table rendered with column sizes adjusted by a proportional integer
[cols="1,2,6"]
include::ex-table.adoc[tag=base]
When assigning percentage values to the cols attribute, you do not need to include the percent sign (`%`).
[source]
----
[cols="50,20,30"]
include::ex-table.adoc[tag=base]
----
.Result: Table rendered with column sizes adjusted by a percentage
[cols="50,20,30"]
include::ex-table.adoc[tag=base]
Let's create a table with custom widths and alignments.
[source]
----
[cols=".<2,.^5,^.>3"]
include::ex-table.adoc[tag=base-xtr]
----
.Result: Rendered table with variable widths and alignments
[cols=".<2,.^5,^.>3"]
include::ex-table.adoc[tag=base-xtr]
[#cols-style]
The style component must always be located at the end of the specifier.
When no style name is provided column contents will be processed as regular inline text.
The column styles are described in the table below.
[cols="20,30m,50"]
|===
|Style Name |Value |Description
|AsciiDoc
|a
|Supports block-level elements (paragraphs, delimited blocks, and block macros).
This style effectively creates a nested, standalone AsciiDoc document.
Implicit attributes such as doctitle from the parent document will be shadowed.
Custom attributes are inherited.
|Emphasis
|e
|Text is italicized
|Header
|h
|Header styles are applied to the column
|Literal
|l
|Column content is treated as if it were inside a literal block
|Monospaced
|m
|Text is rendered in monospaced font
|None (default style)
|d
|Text is handled like a normal paragraph.
Supports all markup (i.e., inline formatting, inline macros) that is permitted in a paragraph.
|Strong
|s
|Text is bolded
|Verse
|v
|Column content is treated as if it were inside a verse block
|===
Let's apply the header style to the first column, the monospaced style to the second, the strong style to the third, and the emphasis style to the fourth.
[source]
----
[cols="h,m,s,e"]
include::ex-table.adoc[tag=4col]
----
.Result: Rendered table with a header, monospaced, and strong styled column
[width="90"]
[cols="h,m,s,e"]
include::ex-table.adoc[tag=4col]
Specifiers can also be applied to individual cells.