什么时候会用到表格

现在,表格<table>一般不再用于网页整体的布局。不过,在面对某些特定的设计,如表单输入、数据呈现时,表格则可能是最恰当的选择。

关于表格的直观印象,就是由多个单元格(cell)整齐排列而成的元素,可以明确看出行(row)和列(column)。这可以联想到Excel,由Excel在数据处理和统计上的地位,就可以理解网页中表格的意义。

简单来说,能直观感受到多个元素是以行和列的概念排列时,用表格会让你轻松很多。如caniuse.com中应用表格的例子:

表格布局计算

使用表格很简单,但有时候表格最终为每一个格子呈现的状态,可能不是你想要的。比如说某些格子出现了换行,然后整个表格就因为换行看起来十分不美观。尤其是用于数据呈现的表格,宽度分配是一个很重要的话题,你可能需要为每一列格子可能呈现的数据情况,对表格的总宽度做精打细算。

这是因为,表格在布局上有自己的特性,它会遵循一定的原理,通过计算,确定出它的实际布局。接下来,本文以实际的表格测试示例,探讨表格是如何计算自己的布局的。
初始声明

本文只针对应用表格最常见的方法,而不会列出所有的情况。不同浏览器对表格的部分概念的解析有差异,但布局计算是基本一致的(如果有差异,会单独提及)。

接下来用的测试表格都会以这样的外观呈现(内容取自零之轨迹):

同时,表格都会设置border-collapse:collapse;和border-spacing:0;。这也是应用表格的最常用做法,Normalize.css把这部分用作了初始化定义。
两种算法

定义在<table>元素上的css属性table-layout,将决定表格在布局计算时应用的算法。它有两种值,auto和fixed。在通常情况下,都使用默认值auto。

这两种算法的差异在于表格的宽度布局是否与表格中的数据内容有关。本文会分别讨论在这两种取值时,表格的布局计算原理。
自动表格布局-auto

自动表格布局的特点是,表格的宽度布局与表格中的所有数据内容有关,它需要在获取所有表格内容后才能确定最终的宽度布局,然后再一起显示出来。

如此看来,要点就是“内容相关”了。如果表格定义了固定宽度(这里是500px),而所有的单元格都不定义宽度(只讨论css定义宽度),会如何呢?来看结果:

上面这个表格中,空白的部分是写了&nbsp;空格。经过比较,可以发现以下几点:

第2列和第3列宽度相同。
    第1列的宽度和后面任意一列的宽度比似乎是2:1。
    加上边框和内边距,所有列的宽度总合,等于表格定义的宽度。

每个单元格都没有定义宽度,所以宽度布局完全由具体的内容数据(文本信息)决定的。如何解释这样的结果呢?可以先直观地推测这样的逻辑:

第1步,从每一列中选取文字内容最多(理解为不换行的情况下,文本所占据的宽度最宽)的,作为“代表”。
    第2步,比较各列的“代表”的宽度,然后按照它们的宽度比例关系,为它们分配表格的总宽度,包括边框和内边距。

参照上面的逻辑,再来反观一下前面的表格,是不是挺有一些道理?注意,前面说宽度比“似乎”是2:1,这个会是?来看看去掉内边距的版本:

用前端调试工具具体看一下上面的单元格的宽度,你会发现这个表格和之前不同,比例已经非常接近2:1(是的,还有的这一小点是因为边框,但是没有边框就没法区分列了)。

可见,在分析宽度比例关系的时候,是会把内容宽度和内边距,以及边框都考虑在内的。这也说明,不是衡量文字的数目,而是衡量文字在不换行状态所能占据的宽度(这里的2:1来源于中文汉字是等宽的)。使用内边距自然只是为了做出更美观的表格 :) 。

有宽度定义的时候,又会怎样呢?下面是一个部分单元格有宽度定义的表格:

它的对应html代码是:

XML/HTML Code复制内容到剪贴板

  1. <table class="exhibit_table">

  2. <tr>

  3. <th>一二</th>

  4. <th style="width:200px;"> </th>

  5. <th> </th>

  6. </tr>

  7. <tr>

  8. <td style="width:5px;"> </td>

  9. <td></td>

  10. <td> </td>

  11. </tr>

  12. <tr>

  13. <td> </td>

  14. <td style="width:70px;"> </td>

  15. <td>一二三四</td>

  16. </tr>

  17. </table>

上面这个表格可以发现以下几点:

宽度定为5px的单元格,实际呈现宽度是13px,这正好是单个汉字的宽度,同一列的有汉字的单元格则以最小单元格宽度的形式排列文字(所以,换行了)。
    宽度定为200px的单元格,实际呈现宽度是200px,尽管同列还有一个宽度70px的定义。
    没有确切宽度定义的第3列,最后得到了表格在分配完第1列和第2列后全部的剩余宽度。

对此的推断是,存在宽度定义和不存在宽度定义的列都有的情况时:

如果单元格定义宽度小于其内容的最小排列宽度(和不换行排列方式相反,尽可能多行排列在单元格内时,单元格所需的宽度),则该单元格所在的列,都会以最小排列方式呈现内容。
    如果同一列中,单元格的内容宽度(不换行形式,后文这个词都是这个意思)小于该列中最大的宽度定义,则该列的实际宽度等于该宽度定义。
    不存在宽度定义的列,会先由表格分配宽度给有宽度定义的列之后,再分配给它们(同样,它们之间的比例取决于内容宽度)。

最前边的没有宽度定义的可以看做情况1,这里有的列有宽度定义,有的又没有,可以看做情况2。下面是情况3,即所有的列都有宽度定义时:

对应html代码:

XML/HTML Code复制内容到剪贴板

  1. <table class="exhibit_table exhibit_table_with_no_padding">

  2. <tr>

  3. <th style="width:50px;"> </th>

  4. <th style="width:50px;"> </th>

  5. <th style="width:100px;"> </th>

  6. </tr>

  7. <tr>

  8. <td> </td>

  9. <td> </td>

  10. <td> </td>

  11. </tr>

  12. <tr>

  13. <td> </td>

  14. <td> </td>

  15. <td> </td>

  16. </tr>

  17. </table>

上面的表格中,去掉了内边距,因此可以清晰地由宽度定义值,得到这3列的宽度比例是2:1:1。这里还有一个条件,就是单元格内的内容宽度不超过宽度定义值。经过测试,IE7及以下在内容超过宽度定义值和其他浏览器表现不同。

从这个表格例子可以知道,如果所有的列都有宽度定义,而这些宽度定义的值的和小于表格的宽度,则表格会在分配完它们宽度定义值所对应的宽度后,继续把剩余宽度,按照它们的宽度比例,也分配给它们。

以上即是对自动表格布局,且表格本身是定义了固定宽度时,3种情况的分析。如果表格本身不定义宽度,还会有更多情况,而且会和表格的包含块(containing block,详情)有关,如果以后有合适机会,再做讨论(所谓文章篇幅有限...)。
固定表格布局-fixed

固定表格布局的特点是,表格的宽度布局和表格中的数据内容无关,只需要接收到表格第一行的信息,就可以确定最终的宽度布局,并开始显示。

固定表格布局是“内容无关”的,而且它强调“第一行”。请看下面这个表格示例:

对应html代码:

XML/HTML Code复制内容到剪贴板

  1. <table class="exhibit_table exhibit_table_fixed">

  2. <tr>

  3. <th style="width:50px;"></th>

  4. <th>一二</th>

  5. <th>一二三四</th>

  6. </tr>

  7. <tr>

  8. <td>艾丝蒂尔·布莱特</td>

  9. <td width="1000px;"> </td>

  10. <td> </td>

  11. </tr>

  12. <tr>

  13. <td style="width:5px;"> </td>

  14. <td> </td>

  15. <td> </td>

  16. </tr>

  17. </table>

固定表格布局的逻辑要简单很多,表述如下:

只取第一行的信息,无视第一行之后的所有单元格的内容,及宽度定义
    在第一行中,如果单元格有宽度定义,则先分配它们所需的宽度,然后剩余的宽度平均分配给没有宽度定义的单元格
    第一行的单元格的宽度分配将决定表格的宽度布局,第一行之后的内容不会再改变布局。

爱建网

还需要注意的时候,使用固定表格布局,则一定要给表格元素定义宽度,如果它的宽度没有定义(也就是auto默认值),浏览器会改用自动表格布局。
结尾声明

与表格有关的其实还有<colgroup>、<thead>、<tfoot>、<caption>等元素,只是在最常见的用法中,并不需要用到它们。实际上,它们也在表格的布局计算的考虑之内。再加上还有单元格合并的情况,你大概可以想象到表格布局计算其实是多么复杂的东西。

W3C的文档提到,表格的布局计算(自动表格布局)尚没有成为规范。关于W3C对表格布局计算的说明,请参照Table width algorithms。
结语

其实就表格布局计算原理这一点,做这样细致的推断,并没有多少实用性。只是说,在需要解决细节问题的时候,有这些信息做参考的话,会有所帮助,尽管这样的机会不多。

不过,可以就本文的内容,得到一个比较有意义的结论:表格定义宽度,且所有单元格都不定义宽度,那么自动布局的表格会尽可能让你的所有数据都不换行,而如果碰到换行影响美观的情况,说明必须要精简数据或者减小边距,而不是再自行尝试重做宽度分配。

这一次做这种实测和推断,感到针对具体情况细分后再说明,会比一次性系统地完整表述,更容易理解,也许算是语文练习?

HTML表格布局实际使用详解,是HTML入门学习中的基础知识相关推荐

  1. 关于python语言的浮点数类型_Python 浮点数数据类型详解(float)[学习 Python 必备基础知识][看此一篇就够了]...

    原博文 2020-04-20 15:25 − > 您的"关注"和"点赞",是信任,是认可,是支持,是动力...... > 如意见相佐,可留言. &g ...

  2. python复数类型转换_Python 复数数据类型详解(complex)[学习 Python 必备基础知识][看此一篇就够了]...

    您的"关注"和"点赞",是信任,是认可,是支持,是动力...... 如意见相佐,可留言. 本人必将竭尽全力试图做到准确和全面,终其一生进行修改补充更新. 1 复 ...

  3. java中batch基础_详解Spring batch 入门学习教程(附源码)

    详解Spring batch 入门学习教程(附源码) 发布时间:2020-09-08 00:28:40 来源:脚本之家 阅读:99 作者:achuo Spring batch 是一个开源的批处理框架. ...

  4. android 动态生成tablelayout,Android 表格布局TableLayout示例详解

    一.表格布局 TableLayout 表格布局TableLayout以行列的形式管理子元素,每一行是一个TableRow布局对象,当然也可以是普通的View对象,TableRow离每放一个元素就是一列 ...

  5. js if for 详解 获取元素方式 及一些js 基础知识

    ##获取元素的新方法## --document.querySelector('Css Selector{css选择器}') 接收一个css选择器(通配,群组,类,包含,id....等) 若这个选择器对 ...

  6. 详解叠瓦式磁记录SMR盘基础知识

    SMR(Shingled Magnetic Recording)叠瓦式磁记录盘是一种采用新型磁存储技术的高容量磁盘.SMR盘将盘片上的数据磁道部分重叠,就像屋顶上的瓦片一样,这种技术被称为叠瓦式磁记录 ...

  7. python录音详解_Python实现电脑录音(含音频基础知识讲解)

    咪哥杂谈 本篇阅读时间约为 6 分钟. 1 前言 今天开始进入近期系列文章的第一篇,如何用 Python 来实现录音功能. 在开始"造轮子"之前,个人一直强调一个观点,如果有些东西 ...

  8. Python零基础速成班-第14讲-Python处理Excel和Word,使用openpyxl和docx包详解,图表入门

    Python零基础速成班-第14讲-Python处理Excel和Word,使用openpyxl和docx包详解,图表入门 学习目标 Python处理Excel(使用openpyxl包).图表入门\ P ...

  9. python布局管理_Python基础=== Tkinter Grid布局管理器详解

    本文转自:https://www.cnblogs.com/ruo-li-suo-yi/p/7425307.html          @ 箬笠蓑衣 Grid(网格)布局管理器会将控件放置到一个二维的表 ...

最新文章

  1. dockefile nginx php,dockerfile自动部署nginx+php7
  2. Javascript添加收藏夹和设为首页兼容写法
  3. java中 快捷键输入System.out.println();
  4. win7服务器端口被占用,高手亲自帮您win7端口被占用的详尽处理要领
  5. SQLServer 2012重启服务后,自增1的标识列一次增长了1000左右
  6. 通过Xsheel命令:获取nginx的安装目录
  7. C/C++基础(不断更新)
  8. vector与list的接口介绍与如何使用以及区别,附代码。
  9. css3 混合,css3混合模式
  10. SQL语法提示工具SQL Prompt教程——控制代码建议框何时弹出
  11. jeb安装教程_JEB2插件教程之一
  12. 在postgre中进行搜索关键字查询的方法
  13. c# 中 event 和 delegate 的区别
  14. 吃鸡什么耳机听声辨位比较好?适合苹果手机的耳机推荐
  15. 福特中国启动“福特更美好的世界“公益项目
  16. 斜杠‘/‘ 和反斜杠‘\‘
  17. 解决uniapp静态文件字体包太大打包大小超出限制
  18. html 怎么把图片变成圆角,css怎么样实现图片圆角
  19. 机器学习实战- 回归(Regression) 概述
  20. 战高端,荣耀亮出“第二把剑”

热门文章

  1. sharepoint入门。
  2. 关于个人学习开发SharePoint的一些资源
  3. 《FreeSWITCH: VoIP实战》: 一个在FreeSWITCH中外呼的Lua脚本
  4. 央行创设央行票据互换工具 为银行发行永续债提供流动性支持
  5. ss-panel config.php,sspanelv3魔改版邮件设置指南及常用配置(示例代码)
  6. 【Python入门教程】第82篇 常用字符串方法之查找子串
  7. java的无参构造函数_Java 无参数构造函数的应用
  8. 免编译安装Nginx_Linux安装Nginx详细教程
  9. 一个带时间的相册页面(仿小米相册)
  10. 相机模型-鱼眼模型(fisheye camera model)