CSS进阶11-表格table

(注1:如果有问题欢迎留言探讨,一起学习!转载请注明出处,喜欢可以点个赞哦!) (注2:更多内容请查看我的目录。)

1. 表格简介

本文定义了CSS中表格的处理模型。这种处理模式的一部分就是布局。对于布局,本文介绍两种算法; 第一种是固定表格布局算法,其定义很明确,但第二种是自动表格布局算法,该规范没有完全定义。

对于自动表格布局算法,一些广泛部署的实现已经实现了相对紧密的互操作性。

表格布局可以用来表示数据之间的表格关系。开发者以文档语言指定这些关系,并可以使用CSS 2.2指定他们的表示。

在可视化媒体中,CSS表格也可以用来实现特定的布局。在这种情况下,开发者不应该在文档语言中使用与表格相关的元素,而应该将CSS应用于相关的结构元素以实现所需的布局。

开发者可以将表格的视觉格式指定为矩形网格单元格。单元格的行和列可以组织成行组和列组。行,列,行组,列组和单元格可以在它们周围绘制边框(CSS 2.2中有两个边框模型)。开发者可以在单元格中垂直或水平对齐数据,并可以将一行或者一列的所有单元格数据对齐。

如下,是一个简单的三行,三列的HTML 4中描述的表格:

<TABLE>
<CAPTION>This is a simple 3x3 table</CAPTION>
<TR id="row1">
   <TH>Header 1  <TD>Cell 1  <TD>Cell 2
<TR id="row2">
   <TH>Header 2  <TD>Cell 3  <TD>Cell 4
<TR id="row3">
   <TH>Header 3  <TD>Cell 5  <TD>Cell 6
</TABLE>

该段代码创建了一个表(TABLE元素),三行(TR元素),三个标题单元格(TH元素)和六个数据单元格(TD元素)。请注意,此示例的三列是隐式指定的:表中的列与标题单元格和数据单元格总共所需的列数一样多。

以下CSS规则令标题单元格中的文本水平居中,并用粗体字显示标题单元格中的文本:

th { text-align: center; font-weight: bold }

接下来的规则将标题单元格的文本与其基线对齐,并垂直居中每个数据单元格中的文本:

th {vertical-align:baseline}
td {vertical-align:middle}

接下来的规则指定顶行将被3px实蓝色边框包围,而其他每行都将被1px实心黑色边框包围:

table   { border-collapse: collapse }
tr#row1 { border: 3px solid blue }
tr#row2 { border: 1px solid black }
tr#row3 { border: 1px solid black }

但请注意,行周围的边框于行相交处重叠。row1和row2之间的边界是什么颜色(黑色或蓝色)和厚度(1px或3px)?我们在关于边界冲突解决的部分讨论这一点 。

以下规则将表头放在表格的上方:

caption { caption-side: top }

上例显示了CSS如何作用于 HTML 4元素; 在HTML 4中,各种表格元素(TABLE,CAPTION,THEAD,TBODY,TFOOT,COL,COLGROUP,TH和TD)的语义是明确定义的。在其他文档语言(如XML应用程序)中,可能没有预定义的表格元素。因此,CSS 2.2允许开发者通过“display”属性将文档语言元素“映射”到表格元素。例如,以下规则使FOO元素行为表现和HTML TABLE元素一样,BAR元素像CAPTION元素一样:

FOO {display:table}
BAR {display:table-caption}

我们在接下来讨论各种表格元素。在本文中,术语表元素table element是指任何涉及创建表的元素。内部表元素internal-table-element是生成行row、行组row group、列column、列组column group或单元格cell的元素。

2. CSS表格模型

CSS表格模型基于HTML4表格模型,其表格结构与表格的可视布局紧密相关。在此模型中,表格由可选标题caption和任意数量行的单元格组成。作者在文档语言中明确表格模型被为“行主要”。一旦指定了所有行,就会派生出列(每行的第一个单元格属于第一列,第二个单元格属于第二列,......)。行和列可以在结构上分组,并且该分组会通过表现反映出来(例如,可能会围绕行来绘制border)。

因此,表格模型由表格tables,标题captions,行 rows,行组row groups(包括标题组header groups和页脚组footer groups),列columns,列组column groups和单元cells组成。

CSS模型不要求文档语言包含对应这些组件的每一个元素。对于没有预定义表元素的文档语言(如XML应用程序),作者必须将文档语言元素映射到表元素,这是通过“display”属性完成的。下面的“display”值将表格格式化规则分配给任意元素:

  • table (In HTML: TABLE) 指定元素定义块级表格block-level table:它是参与BFC的矩形块。
  • inline-table (In HTML: TABLE) 指定元素定义行内级表格inline-level table:它是参与IFC的矩形块。
  • table-row (In HTML: TR) 指定元素是行单元格
  • table-row-group (In HTML: TBODY) 指定元素是一行或多行的分组
  • table-header-group (In HTML: THEAD) 与'table-row-group'类似,但对于视觉格式化,该行组始终显示在所有其他行和行组之前以及任何顶部标题top captions之后。打印用户代理可以在表的每一页上重复标题行。如果一个表包含具有'display:table-header-group'的多个元素,则只有第一个元素被渲染为标题; 其与元素被视为具有'display: table-row-group'。
  • table-footer-group (In HTML: TFOOT) 与'table-row-group'类似,但对于视觉格式化,该行组始终显示在所有其他行和行组之后以及任何底部标题bottom captions之前。打印用户代理可以在表的每一页上重复页脚行。如果一个表包含具有'display:table-header-group'的多个元素,则只有第一个元素被渲染为标题; 其与元素被视为具有'display: table-row-group'。
  • table-column (In HTML: COL) 指定元素描述一列单元格
  • table-column-group (In HTML: COLGROUP) 指定元素是一列或多列的分组
  • table-cell (In HTML: TD, TH) 指定一个元素表示一个表格单元格。 table-caption (In HTML: CAPTION) 为表指定一个标题,即表头。所有带有'display:table-caption'的元素都必须被渲染,如17.4节所述。

具有这些display值的替换元素在布局过程中被视为其给定的display类型。例如,设置为'display:table-cell'的图像将填充可用的单元格空间,其尺寸可能会影响表格大小算法,如同普通单元格一样。

将display设置为'table-column'或'table-column-group'的元素不会被渲染(就像它们有'display:none'一样),但是它们是有用的,因为它们可能具有某些属性为其所代表的列包含特定的样式。

附录中 default style sheet for HTML4说明了如何将这些值用于HTML4:

table    { display: table }
tr       { display: table-row }
thead    { display: table-header-group }
tbody    { display: table-row-group }
tfoot    { display: table-footer-group }
col      { display: table-column }
colgroup { display: table-column-group }
td, th   { display: table-cell }
caption  { display: table-caption }

用户代理可能忽略HTML表元素的这些“display”属性值,因为HTML表可能会使用其他用于向后兼容渲染的算法呈现。然而,这并不意味着鼓励在HTML中的其他非表元素中不使用“display: table”。

2.1 匿名表格对象 Anonymous table objects

HTML以外的文档语言可能不包含CSS 2.21表模型中的所有元素。在这些情况下,必须假定“缺失”元素才能使表格模型起作用。任何table元素都会自动生成必要的匿名表对象,由至少三个对应于'table'/'inline-table'元素,'table-row'元素和'table-cell'元素的嵌套对象组成。缺失元素根据以下规则生成匿名对象(例如,可视化表格布局中的匿名盒): 我们为这些规则定义如下术语:

  • row group box A 'table-row-group', 'table-header-group', or 'table-footer-group'
  • proper table child A 'table-row' box, row group box, 'table-column' box, 'table-column-group' box, or 'table-caption' box.
  • proper table row parent A 'table' or 'inline-table' box or row group box
  • internal table box A 'table-cell' box, 'table-row' box, row group box, 'table-column' box, or 'table-column-group' box.
  • tabular container A 'table-row' box or proper table row parent
  • consecutive Two sibling boxes are consecutive if they have no intervening siblings other than, optionally, an anonymous inline containing only white spaces. A sequence of sibling boxes is consecutive if each box in the sequence is consecutive to the one before it in the sequence.

出于这些规则的目的,脱离标准流元素被视为零宽度零高度的行内元素。它们的包含块也会被对应此选择。

以下步骤分三个阶段进行:

  1. 删除不相关的框Remove irrelevant boxes: 1.1 父级为'table-column'的所有子盒都被视为具有'display:none'。 1.2 如果父级“table-column-group”的子级C不是'table-column'盒,则将其视为具有“display:none”。 1.3 如果表格容器P的子级C 是只包含空格的匿名行内盒,并且其紧接前面和后面的兄弟(如果有的话)是P的roper table descendants,并且是''table-caption''或internal table boxes,那么它被视为具有'display:none'。如果D能够是A的后代且不产生任何位于其内的'table'或“'inline-table'”的盒子,那么D是A的proper table descendant。 1.4 如果盒B是只包含空格的匿名行内盒,并且位于两个直接的兄弟之间,每个兄弟都是internal table box或者'table-caption' box,则将B视为具有“display:none”。
  2. 生成丢失的子包装器Generate missing child wrappers: 2.1 如果'table' 或 'inline-table' 盒中的子级C不是一个proper table child,那么将会生成一个anonymous 'table-row' box围绕C和C的那些不是proper table children的consecutive siblings 2.2 如果row group box盒中的子级C不是一个 'table-row' box,那么将会生成一个anonymous 'table-row' box围绕C和C的那些不是'table-row' boxes的consecutive siblings 2.3 如果'table-row'盒中的子级C不是一个 table-cell',那么将会生成一个anonymous 'table-cell' box围绕C和C的那些不是'table-cell' boxes的consecutive siblings
  3. 生成失踪父级 Generate missing parents: 3.1 对于一系列consecutive internal table和'table-caption' siblings中的每个'table-cell' box C,如果C的父级不是table-row',那么将会生成一个anonymous 'table-cell' box围绕C和C的那些是'table-cell' boxes的所有consecutive siblings 3.2 对于一系列roper table children中的一个proper table child C ,如果C是misparented,那么将会生成一个anonymous 'table' or 'inline-table' box T围绕C和 C的那些是proper table children的consecutive siblings(如果C的父级是'inline' box,那么T必须是 'inline-table' box;;否则它必须是 'table' box。)
  • 当'table-row'的父级既不是row group box也不是'table' 或者'inline-table' box时,称其为misparented。
  • 当'table-column' box的父级既不是'table-column-group' box也不是'table' 或者'inline-table' box时,称其为misparented。
  • 当 row group box, 'table-column-group' box, 或者 'table-caption' box的父级既不是'table' box 也不是 'inline-table' box时,称其为misparented。

3. 列 Columns

表格单元格可能属于两个上下文:行和列。但是,在源文档中,单元格是行的后代,而不是列。尽管如此,通过在列上设置属性可以影响单元格的某些方面。

以下属性适用于column和column-group元素:

以下是在列上设置属性的样式规则的一些示例。前两条规则一起执行HTML 4的“rules”属性,其值为“cols”。第三条规则使“totals”列变为蓝色,最后两条规则通过使用固定布局算法fixed layout algorithm显示如何使列成为固定大小。

col { border-style: none solid }
table { border-style: hidden }
col.totals { background: blue }
table { table-layout: fixed }
col.totals { width: 5em }

4. 视觉格式化模型中的表格 Tables in the visual formatting model

就VFM而言,table可以表现为 block-level(用于'display:table')或 inline-level(用于'display:inline-table')元素。

在这两种情况下,该表都会生成一个称为表格包装盒table wrapper box的主要块容器盒principal block container box ,其中包含table box本身和任何caption boxes(按文档顺序)。该table box是包含表的内部表盒internal table boxes的一个块级盒。caption boxes是主要的块级盒,它们保留自己的content, padding, margin, and border 区域,并在表格包装盒内呈现为普通块盒。caption boxes放置在table box之前还是之后由'caption-side'属性决定,后面会讲到。

table wrapper box对于'display:table'是块级的,对于 'display:inline-table'是行内级的。table wrapper box建立一个BFC,而table box建立一个表格格式上下文table formatting context.。table box (不是table wrapper box)用于为“inline-table”执行基线垂直对齐。table wrapper box的宽度是其内部table box 的border-edge width,如第17.5.2节所述。作用于table的“width”和“height”的百分比值是相对于table wrapper box的 containing block,而不是table wrapper box本身。

table element的属性 'position', 'float', 'margin-*', 'top', 'right', 'bottom', 和 'left'的计算值作用于table wrapper box而不是table box; 所有其他非可继承属性的值作用于 table box而不是table wrapper box。(当table box和table wrapper box中未使用table element的值时,将使用初始值initial values替代。)

上面有标题的表格图Diagram of a table with a caption above it

4.1 标题的位置和对齐Caption position and alignment

caption-side

此属性指定caption box相对于table box的位置。其值具有以下含义:

  • top 将caption box置于table box上方。
  • bottom 将caption box置于table box下方。

注:CSS2描述了不同的宽度和水平对齐行为。该行为将在CSS3中使用此属性的值“top-outside”和“bottom-outside”引入。

如果要在caption box内水平对齐标题内容,请使用'text-align'属性。

在此示例中,“caption-side”属性将标题放置在表格下方。标题将与表格的父项一样宽,并且标题文本将左对齐。

caption { 
    caption-side: bottom; 
    width: auto;
    text-align: left
}

5. 表格内容的可视化布局 Visual layout of table contents

Internal table elements生成的矩形盒box,会参与由table box创建的表格格式上下文TFC。这些框有content和borders,cells也有padding。Internal table elements没有margins。

这些框的视觉布局是由一个矩形的、不规则的行和列网格控制的。每个盒子占据了整个网格单元的数量,根据下面的规则来确定。这些规则不适用于HTML 4或早期的HTML版本;HTML对行和列跨度有自己的限制。

  1. 每个row box占据一行网格单元格grid cells。这些row boxes在一起按照它们在源文档中出现的顺序从上到下填充表格(即,表格占据与行元素一样多的网格行)。
  2. row group占据与其包含的行相同的网格单元格。
  3. column box占用一列或多列网格单元格。Column boxes按照它们出现的顺序彼此相邻放置。第一列盒可以在左侧或右侧,具体取决于表的'direction'属性的值。
  4. column group box与其包含的列占据相同的网格单元格。
  5. 单元格可能会跨越多行或多列。(虽然CSS 2.2没有定义如何确定跨越行或列的数量,但用户代理可能对源文档有特殊的理解; CSS的未来更新可能提供了一种用CSS语法表达这种理解的方法。)因此每个单元格是一个矩形盒,具有一个或多个网格单元的宽度和高度。此矩形的top row位于单元格的父级所指定的行中。矩形必须尽可能地靠近左边,但它所占据的第一列中的单元格部分不能与任何其他单元格框重叠(比如,在前一行中开始的跨行单元格row-spanning cell),并且该单元格必须位于源文档中较早的同一行中的所有单元格的右侧。如果这个位置会导致跨列单元格column-spanning cell与先前行中的跨行单元格row-spanning cell重叠,那么CSS不会定义结果:实现可能会重叠单元格(如许多HTML实现中所做的那样),也可能会移动较晚的单元格到右边以避免这种重叠。(如果表的'direction'属性为'ltr',则该约束成立;如果'direction'为'rtl',交换前面句子中的左和右)
  6. 单元格盒cell box不能超出表或行组row group的最后一个行盒row box; 用户代理必须将其缩短到适合为止。 折叠边框模型collapsing borders model中的rows, columns, row groups 和 column groups的 edges与单元格borders居中的假想网格线hypothetical grid lines重合。(因此,在这个模型中,所有行一起正好覆盖表格,不留空隙;对于列也是如此)。在 分隔边框模型separated borders model中edges与单元格的border edges重合。(因此,在此模型中,在rows, columns, row groups 和column groups之间可能存在对应于'border-spacing'属性的间隙。) 注:根据9.7节的规则,table cells 的定位和浮动可能会导致它们不再成为table cells。使用浮动时,anonymous table objects上的规则也可能导致创建anonymous cell object。 下面是说明规则5的示例。下面的非法(X)HTML片段定义了相互冲突的单元格:
<table>
<tr>
  <td>1 </td>
  <td rowspan="2">2 </td>
  <td>3 </td><td>4 </td>
</tr>
<tr>
  <td colspan="2">5 </td>
</tr>
</table>

用户代理可以在视觉上重叠单元格,如左图所示,或者移动单元格以避免视觉重叠,如右图所示:

错误表格的两种可能渲染方式Two possible renderings of an erroneous HTML table

5.1 表格层次和透明度 Table layers and transparency

为了找到每个表格单元格的背景,不同的表格元素可以被认为是在六个叠加层上。在其中一个图层中的元素上设置的背景只有在它上面的图层具有透明背景时才可见。

表层架构Schema of table layers

  1. 最底层是一个单独的平面,代表表格本身。像所有的盒子一样,它可能是透明的。
  2. 上一层包含column groups。每个column group从顶行的单元格的顶部延伸到底行的单元格的底部,并从其最左列的左边缘延伸到其最右列的右边缘。背景完全覆盖了来自column group中所有单元格的全部区域,即使它们跨越到column group之外,但这种区域差异不会影响背景图像定位background image positioning。
  3. column groups顶部是代表column boxes的区域。每个column与column groups一样高,并且与列中的标准(单列跨越single-column-spanning)单元格一样宽。背景完全覆盖了来自列的所有单元格的全部区域,即使它们跨越到列之外,但这种区域差异不会影响背景图像定位。
  4. 接下来是包含行组row groups的图层。每个行组从其最顶端单元格的左上角延伸到最后一列最底部单元格的右下角。
  5. 倒数第二层包含行rows。每一行都与行组一样宽,并且与行中标准(单行跨越single-row-spanning)单元一样高。与列一样,背景完全覆盖了来自该行的所有单元格的全部区域,即使它们跨越到行之外,但这种区域差异不会影响背景图像定位。
  6. 最顶层包含单元格cells本身。如图所示,虽然所有行都包含相同数量的单元,但并非每个单元都可能具有指定的内容。在 分隔边框模型中separated borders model属性'border-collapse'的值是'separate'),如果属性'empty-cells'的值是'hide',则这些“空”单元格是透明的,会穿越cell, row, row group, column 和 column group的背景,直接显示表格背景。

"missing cell"是行/列网格row/column grid中未被元素或伪元素占据的单元格。Missing cells的单元格就像被一个anonymous table-cell box占据了它们在网格中的位置一样被渲染。 在下面的示例中,第一行包含四个非空单元格non-empty cells,但第二行仅包含一个非空单元格,因此表格背景会被穿透展示,除非第一行的单元格跨越此行。以下是HTML代码和样式规则:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
<HTML>
  <HEAD>
    <TITLE>Table example</TITLE>
    <STYLE type="text/css">
      TABLE  { background: #ff0; border: solid black;
               empty-cells: hide }
      TR.top { background: red }
      TD     { border: solid black }
    </STYLE>
  </HEAD>
  <BODY>
    <TABLE>
      <TR CLASS="top">
        <TD> 1 
        <TD rowspan="2"> 2
        <TD> 3 
        <TD> 4 
      <TR>
        <TD> 5
        <TD>
    </TABLE> 
  </BODY>
</HTML>

可能会被格式化如下:

表格底部有空单元格Table with empty cells in the bottom row

请注意,如果表具有'border-collapse:separate'属性,则由'border-spacing'属性给出的区域的背景总是表格元素的背景。详见分离的边框模型

5.2 表宽度算法: 'table-layout'属性 Table width algorithms: the 'table-layout' property

CSS并没有为表格定义一个“最佳”布局,因为在许多情况下,”最佳“就是一个品味问题。CSS确定了用户代理在表格布局时必须遵守的约束。用户代理可以使用他们想做的任何算法,并且可以自由地选择渲染速度而不是精度,除非选择了“固定布局算法fixed layout algorithm”。 请注意,本节将重写如第10.3节section 10.3 所述的适用于计算宽度的规则。特别是,如果一个表的边距margins设置为“0”和“auto”的宽度,则表格不会自动调整大小以填充其包含的块。然而,一旦找到了表的“width”的计算值(使用下面给出的算法,或者在适当情况下,使用其他一些UA依赖算法),那么第10.3节部分的其他部分就应用了。因此,一个表可以使用左右两个'auto' margins实现居中。 CSS的未来更新可能会引入使表格自动适应其包含块的方法。

table-layout

‘table-layout’属性用于控制应用于表的cells, rows,和columns的布局算法。其值具有如下含义:

  • fixed 使用固定表格布局算法fixed table layout algorithm
  • auto 使用任何自动表格布局算法automatic table layout algorithm 这两种算法如下所述。
5.2.1 固定表格布局fixed table layout

使用这种(快速)算法,表的水平布局不依赖于单元格内容; 它仅取决于表格的宽度,列的宽度以及borders或者单元格间距cell spacing。

表格的宽度可以用'width'属性明确指定。如果该属性值为'auto'(对于'display:table'和'display:inline-table')意味着使用自动表格布局算法。但是,如果该表是标准流中的块级表('display:table'),则UA可以(但不是必须)使用10.3.3的算法计算宽度并应用固定表格布局,即使指定的width是'auto'。 如果UA在'width'为'auto'时支持固定表格布局,则以下内容将创建一个比其包含块窄4em的表格:

table {
    table-layout: fixed;
    margin-left: 2em;
    margin-right: 2em
}

在固定表格布局算法中,每列的宽度确定如下:

  1. 如果列元素的'width'属性的值不是'auto',该值表示该列的宽度。
  2. 否则,该列的宽度有第一行中'width'属性值不是'auto'的单元格确定。如果该单元格跨越多个列,则宽度分散到各个列。
  3. 任何剩余的列等分剩余的水平表空间(减去边框borders或单元格间距cell spacing)。

表格的宽度是表格元素的'width'属性的值和所有列宽的总和(加上单元格间距或边框)中较大的那个 。如果表格比列宽,额外的空间应该分布在列上。

如果后续行的列数多于由表列元素table-column elements和第一行确定的数字中的较大值,多余的列不会被渲染。如果它们被渲染,CSS 2.2没有定义列和表的宽度。当使用'table-layout:fixed'时,开发者不应该忽略第一行的列。

以这种方式,一旦接收到完整的第一行,用户代理就可以开始进行表格布局。后续行中的单元格不会影响列宽。任何具有溢出内容的单元使用“overflow”属性来确定是否裁剪溢出内容。

***** 5.2.2 自动表格布局 Automatic table layout 在这个算法(通常不会超过两遍)中,表的宽度是由其列的宽度(以及插入边界intervening borders)给出的。该算法反映了在编写该规范时几种流行的HTML用户代理的行为。在'table-layout'为'auto' 的情况下,UA不需要实现该算法来确定表格布局; 他们可以使用任何其他算法,即使会导致不同的行为。

对自动表格布局的输入只能包含包含块的宽度 以及 表格及其任何后代的内容和其上设置的任何CSS属性。 本节其余内容是非规范性的。该算法可能导致效率低下。在此算法中,行(和行组)和列(和列组)都约束并受其包含的单元的维度约束。设置列的宽度可能会间接影响行的高度,反之亦然。在此不予详述。可以参考Column widths

5.3 表格高度算法 Table height algorithms

表格高度由'table'或'inline-table'元素的'height'属性给出。'auto'值表示高度是行高度row heights加上任何单元格间距cell spacing或边界borders的总和。任何其他值都被视为最小高度。当“height”属性导致表格变高时,CSS 2.2没有定义多余的空间如何分布。 一旦用户代理具有行中的所有单元格,就计算'table-row'元素框的高度:它是行计算的'height'的最大值,行中每个单元格计算的'height'和单元格所需的最小高度(MIN)。“表格行” 的height值为“auto”表示用于布局的行高度是MIN。MIN取决于单元格高度和单元格对齐方式(很像计算行盒line box高度)。CSS 2.2没有定义表单元格和表行的高度是如何用百分比值指定其高度的。CSS 2.2没有定义行组上“高度”的含义。

在CSS 2.2中,单元格盒的高度是内容所需的最小高度。表格单元格的height属性可以影响行的高度(请参见上文),但不会增加单元格盒的高度。

CSS 2.2没有指定跨越多行的单元格如何影响行高计算,但所涉及行高的总和必须足够大以涵盖跨行的单元格。

每个表格单元格的'vertical-align'属性决定了它在行内的对齐方式。每个单元格的内容都有一个基线baseline,一个顶部top,一个中间middle和一个底部bottom,行本身也是如此。在表格的上下文中,'vertical-align'的值具有以下含义:

  • baseline 单元格的基线与它所跨越的第一行的基线高度相同(见下面单元格和行基线的定义)。
  • top 单元格盒的顶部与它所跨越的第一行的顶部对齐。
  • bottom 单元格盒的底部与它的最后一行的底部对齐。
  • middle 单元格的中心与它所跨越的行的中心对齐。
  • sub, super, text-top, text-bottom, <length>, <percentage> 这些值不适用于单元格;单元格在基线上对齐。

单元格的基线是单元格中第一行标准流内行盒line box的基线,或单元格中第一个标准流内表行table-row的基线,以第一个为准。如果没有这样的行框或表行,则基线是单元格盒的内容边缘content edge的底部。为了查找基线,必须将具有滚动机制的标准流内盒子(请参阅'overflow'属性)视为滚动到其原始位置。注意,单元格的基线可能会低于其底部边界,请参见下面的示例。 所有单元格中“vertical-align”的单元格顶部与基线之间的最大距离用于设置该行的基线。这里有个例子:

显示表格单元格中'vertical-align'各种值的影响的图表Diagram showing the effect of various values of 'vertical-align' on table cells

单元格盒cell box1和2在其基线上对齐。单元格盒2具有基线以上的最大高度,因此可以确定该行的基线。 如果某行没有与其基线对齐的单元格盒,则该行的基线是该行中最低单元格的底部内容边缘。 为了避免模棱两可的情况,单元格的排列按以下顺序进行:

  1. 首先定位在其基线上对齐的单元格。这将建立该行的基线。接下来定位'vertical-align:top'的单元格。
  2. 该行现在具有top,可能是基线,以及临时高度,其是从目前定位的单元格的3. 顶部到底部的距离。(请参阅下面的单元格填充条件。)
  3. 如果任何剩余的单元格(在底部或中间对齐的单元格)的高度大于行的当前高度,则通过降低底部,行的高度将增加到这些单元格的最大高度。
  4. 最后剩下的单元格盒被定位。

小于该行高度的单元格盒会收到额外的顶部或底部padding。

此示例中的单元格的底部边界下方有一个基线:

div { height: 0; overflow: hidden; }

<table>
 <tr>
  <td>
   <div> Test </div>
  </td>
 </tr>
</table>

5.4 列中的水平对齐 Horizontal alignment in a column

单元格盒中inline-level content的水平对齐可以通过单元格上的'text-align'属性值来指定。

5.5 动态行和列效应 Dynamic row and column effects

row, row group, column和 column group元素的“visibility”属性值可以取为'collapse'。该值导致整个行或列从显示中移除,并且由行或列正常占据的空间将用于其他内容。与折叠的列或行相交的跨行和列的内容会被剪切。但是,对行或列的抑制不会影响表格的布局。这允许动态效果删除表格行或列而不强制对表格进行重新布局,以考虑列约束中的潜在变化。

6. 边框 borders

为CSS中的表单元格设置边界有两种不同的模式。其中一个适用于在单个单元格盒周围的所谓分离边框separated borders,另一个适合于从表的一端到另一端的连续边界。这两种模式都可以实现许多边界样式,所以决定使用哪一种通常只是开发者的品味而已。

border-collapse

该属性选择表格的边框模型。值'separate'选择分离边框边框模型separated borders border model。值'collapse'选择折叠边框模型collapsing borders model。这些模型如下所述。

6.1 分离边框模型 The separated borders model

border-spacing

注意:用户代理也可以将'border-spacing'属性应用于'frameset'元素。本规范并未定义哪些元素是'frameset'元素,这取决于文档语言。例如,HTML4定义了一个<FRAMESET>元素,而XHTML 1.0定义了一个<frameset>元素。'frameset'元素上的'border-spacing'属性可以被用作非标准'framespacing'属性的有效替代。

lengths指定分隔相邻单元格边界的距离。如果指定了一个length,则会同时提供水平和垂直间距。如果指定了两个,则第一个给出水平间距,第二个给出垂直间距。length不一定是负值。

表边框和单元格边缘之间的距离是表的内边距padding ,加上相应的边框间距border spacing distance。例如,在右侧,距离是padding-right + horizontal border-spacing。

表格边框与表格边框之间的距离是该表格的边框填充以及相关的边框间距。例如,在右侧,距离是填充右边 + 水平边框间距。

表的宽度是从left inner padding edge到right inner padding edge的距离(包括border spacing,但不包括padding 和 border)。

但是,在HTML和XHTML1中,<table>元素的宽度是从left border edge 到right border edge 的距离。 注:在CSS3中,这个特殊的需求将根据UA样式表规则和'box-sizing'属性来定义。

在这个模型中,每个单元都有一个单独的边界。在“border-spacing”属性指定相邻单元格的border之间的距离。在此空间中,row, column, row group, 和 column group的背景不可见,允许表格背景显示。row, column, row group, 和 column group不能有borders(即用户代理必须忽略这些元素的边框属性)。 下图中的表格可能是这样的样式表的结果:

table      { border: outset 10pt; 
             border-collapse: separate;
             border-spacing: 15pt }
td         { border: inset 5pt }
td.special { border: inset 10pt }  /* The top-left cell */

[图片上传失败...(image-c9df60-1520163880252)] set to a length value. Note that each cell has its own border, and the table has a separate border as well. ](http://upload-images.jianshu.io/upload_images/4761597-9d57ab0938aca069.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

6.1.1 #### 边框和空单元格周围背景: 'empty-cells'属性 Borders and Backgrounds around empty cells: the 'empty-cells' property

empty-cells

在separated borders model中,此属性控制在没有可见内容的单元格周围绘制边框和背景。“visibility”属性设置为“hidden”的空单元格和单元格被视为没有可见内容。单元格为空,除非它们包含以下一项或多项:

  • floating content (including empty elements),
  • in-flow content (including empty elements) other than white space that has been collapsed away by the 'white-space' property handling. 当这个属性的值为'show'时,在空单元格周围/背后绘制边框和背景(像普通单元格一样)。 'hide'的值表示在空单元格周围/后面没有绘制边框或背景(参见17.5.1中的点6 )。此外,如果一行中的所有单元格都具有“hide”值并且没有可见内容,则该行的高度为零,并且该行仅一侧有垂直边界间距。 以下规则会在所有单元格周围绘制边框和背景:
table { empty-cells: show }

6.2 折叠边框模型 The collapsing border model

在 collapsing border model中,可以指定围绕全部或部分单元格,行,行组,列和列组的边框。HTML的“rules”属性的边界可以用这种方式指定。 边框以单元格之间的网格线为中心。在奇数个离散单位(屏幕像素,打印机点)的情况下,用户代理必须找到一致的舍入规则。

下表显示了表格的宽度,边框的宽度,填充和单元格宽度如何相互作用。它们的关系由以下等式给出,该等式适用于表的每一行:

这里n是行中单元的数量, padding-lefti 和 padding-righti 分别指的是单元格的左右padding,和 border-widthi 指单元格i和i+1之间的border。

UA必须通过检查表格第一行中的第一个和最后一个单元格来计算表格的初始左边界和右边界宽度。表格的左边框宽度是第一个单元格的折叠左边框的一半,并且该表格的右边框宽度是最后一个单元格的折叠右边框的一半。如果后面的行具有较大的折叠左右边界,则任何多余部分溢出到表格的margin area。

表格的顶部边框宽度是通过检查所有用表格顶部边框折叠顶部边框的单元格来计算的。表格的顶部边框宽度等于最大折叠顶部边框的一半。通过检查底部边界与表底部折叠的所有单元格计算底部边框宽度。底部边框宽度等于最大折叠底部边框的一半。

当确定表是否溢出某个祖先时,会考虑溢出到margin中的任何border(参见'overflow')。

Schema showing the widths of cells and borders and the padding of cells.

请注意,在此模型中,表格的宽度包括表格border的一半。而且,在这个模型中,一个表格没有padding(但有margin)。

CSS 2.2没有定义表格元素背景边缘的位置。

6.2.1边界冲突解决Border conflict resolution

在collapsing border model中,每个单元格的每个边缘处的边框可以由在该边缘处相遇的各种元素(单元格,行,行组,列,列组和表格本身)上的边界属性指定,并且这些边框的宽度,样式和颜色可能会有所不同。经验法则是,在每个边缘选择最“醒目”的边框样式,除非任何出现的“hidden”样式无条件地关闭边框。

以下规则确定在冲突情况下哪个边框样式“获胜”:

  1. 具有“ 'border-style'属性为'hidden'的border优先于所有其他冲突borders。任何具有此值的边框都会阻止此位置的所有边框。
  2. style为“none”的边界优先级最低。只有在此边缘上所有元素的边框属性都是'none'时,边框才会被省略(但请注意'none'是边框样式的默认值。)
  3. 如果没有一种样式是“hidden”,并且其中至少有一种样式不是“none”,那么窄边框将被丢弃以支持更宽的边框。如果几个驳岸狂具有相同的'border-width', 则style按照以下顺序排列:'double', 'solid', 'dashed', 'dotted', 'ridge', 'outset', 'groove', and the lowest: 'inset'.
  4. 如果边框样式仅在颜色上有所不同,则style按照以下顺序排列cell, row, row group, column, column group and, lastly, table。当两个相同类型的元素发生冲突时,则离左边更远(如果表的'方向'是'ltr',则是右侧,如果它是'rtl'),并且离顶部更远的元素获胜。 以下示例说明了这些优先规则的应用:
table          { border-collapse: collapse;
                 border: 5px solid yellow; }
*#col1         { border: 3px solid black; }
td             { border: 1px solid red; padding: 1em; }
td.cell5       { border: 5px dashed blue; }
td.cell6       { border: 5px solid green; }


<TABLE>
<COL id="col1"><COL id="col2"><COL id="col3">
<TR id="row1">
    <TD> 1
    <TD> 2
    <TD> 3
</TR>
<TR id="row2">
    <TD> 4 
    <TD class="cell5"> 5
    <TD class="cell6"> 6
</TR>
<TR id="row3">
    <TD> 7
    <TD> 8
    <TD> 9
</TR>
<TR id="row4">
    <TD> 10
    <TD> 11
    <TD> 12
</TR>
<TR id="row5">
    <TD> 13
    <TD> 14
    <TD> 15
</TR>
</TABLE>

会有如下结果:

An example of a table with collapsed borders

这是一个隐藏的折叠边框的例子:

<TABLE style="border-collapse: collapse; border: solid;">
<TR><TD style="border-right: hidden; border-bottom: hidden">foo</TD>
    <TD style="border: solid">bar</TD></TR>
<TR><TD style="border: none">foo</TD>
    <TD style="border: solid">bar</TD></TR>
</TABLE>

Table with two omitted internal borders

6.3 边框样式 Border styles

“border-style”的某些值在表中的含义不同于其他元素。在下面的列表中,他们用星号标出。

参考

https://www.w3.org/TR/CSS22/tables.html css Table布局-display:table MDN-cn-table MDN-en-table

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏CaiRui

CSS再学

css的注释 /*.......*/ 直接在html代码中写css <p style="color: rebeccapurple;font-size: 18px...

19370
来自专栏阮一峰的网络日志

SVG 图像入门教程

SVG 是一种基于 XML 语法的图像格式,全称是可缩放矢量图(Scalable Vector Graphics)。其他图像格式都是基于像素处理的,SVG 则是...

11510
来自专栏Nian糕的私人厨房

CSS 基础

层叠样式表 (Cascading Style Sheets),一种用来为结构化文档(如 HTML 文档或 XML 应用)添加样式(字体、间距和颜色等)的计算机语...

13540
来自专栏cnblogs

Css3新特性应用之形状

一、自适应椭圆 * border-radius特性:     * 可以单独指定水平和垂直半径,并且值可以是百分比,用/(斜杠)分隔这两个值即可(可以实现自适应宽...

18890
来自专栏三木的博客

CSS概要

CSS 基础知识 语法 CSS全称为“层叠样式表 (Cascading Style Sheets)”,它主要是用于定义HTML内容在浏览器内的显示样式, 如文字...

20550
来自专栏Android小菜鸡

自定义View学习之路(二)————Paint与Canvas

  Canvas可以理解为画布,配置好画笔后,我们可以调用Canvas的各种绘制方法。   绘制直线:canvas.drawLine(float startX...

10810
来自专栏腾讯IVWEB团队的专栏

Canvas 实现 progress 效果

分享下一个简单的Canvas插件 ,Canvas元素是HTML5的一部分,允许脚本语言动态渲染位图像,你可以使用javascript用它来绘制图形。

63800
来自专栏jiajia_deng

Qt 用画笔对图片实现马赛克效果

最近接了一个用 Qt 做跨平台截图工具的任务,主要功能有截图、绘制图案、马赛克、毛玻璃、文字能效果,其中马赛克功能时参考网上的文献并自己研究制作出来的,这里特意...

32110
来自专栏静晴轩

CSS征途之Background点滴

CSS虽算不上编程语言,确是能够真正做到网页表现与内容分离的一种样式设计语言。相对于传统HTML的表现而言,CSS能够对网页中的对象的位置排版进行像素级的精确控...

34440
来自专栏抠抠空间

css属性详解

一、字体属性 字体   font-family可以把多个字体名称作为一个“回退”系统来保存。如果浏览器不支持第一个字体,则会尝试下一个。浏览器会使用它可识...

31990

扫码关注云+社区

领取腾讯云代金券