前言:

分离边框模型和合并边框模型是表格的两种模型,它通过以下属性确定:

border-collapse:separate(默认值) | collapse | inherit

当采用分离边框模型时,表格单元格宽度是相当清晰的,和盒模型几乎一致。

当使用合并边框模型时,则不太明了,可能产生以下疑问:

(1)两个单元格的边框合并成了一个边框,那么这个边框究竟算谁的呢?

(2)现在各单元格内容区宽度如何计算呢?

示例

    <div id="container">
<table class="content-table">
<colgroup>
<col width='100'>
<col width='100'>
<col width='100'>
<col width='100'>
<col width='80'>
<col width='80'>
<col width='80'>
<col width='80'>
</colgroup>
<thead>
<tr>
<th>姓名</th>
<th>语文</th>
<th>数学</th>
<th>英语</th>
<th>物理</th>
<th>化学</th>
<th>生物</th>
<th>总分</th>
</tr>
</thead>
<tbody>
<tr>
<td>赵一</td>
<td>80</td>
<td>90</td>
<td>79</td>
<td>56</td>
<td>56</td>
<td>79</td>
<td>98</td>
</tr>
</tbody>
</table>
</div>

CSS:

        #container{
height: 500px;
padding: 10px;
border: 1px solid green;
}
.content-table{
table-layout: fixed;
border-collapse: collapse;
}
.content-table td,.content-table th{
padding: 1px;
border: 1px solid blue;
}

分析

这里每列都被设置了宽度,由于table固定布局根据第一行宽度设置确定每列列宽,那么每一列的列宽将是确定的。现在的问题是,每列单元格的内容区宽度是多少?

事实上,每列内容区宽度分别为:97px,97px,97px,97px,77px,77px,77px,77px,这的确是些意料之外的数字。

第一,将以上数字各加2px的padding,再加上9个1px的边框,则得到表格总宽度721px。我们在chrome浏览器调试工具的Elements标签内,点击table元素,可以发现表格实际宽度的确为721px,如下所示:



第二:我们设置的表格宽度为100px+100px+100px+100px+80px+80px+80px+80px=720px,总宽度为720px与上面所述721px有1px的宽度差。在chrome中查看盒模型的宽度,可以看到,浏览器认为我们设置的宽度的确为720px,如下:



第三,两个宽度不一致的原因在于,720px是浏览器根据我们设置的各列宽度简单相加得到的理论宽度值。然而,浏览器渲染表格有一套略为复杂的机制,721px实际渲染宽度值。这里来分析一下各列的实际渲染宽度值计算:

(1)每个边框宽度1px,由于合并单元格,这将使得每个单元格左右边框实际都为单个边框的一半,即0.5px;左右边框宽度加起来为0.5px+0.5px=1px

(2)每个单元格左右内边距1px,则每个单元格边框加上左右内边距为1px+1px*2=3px

(3)每列宽度则为设置宽度减去3px,即97px,97px,97px,97px,77px,77px,77px,77px

(4)表格实际宽度:由于第一列左边多出0.5px边框,最后一列右边多出0.5px边框,则合计将多出1px宽度,即721px

CSS开发技巧(二):表格合并边框后的单元格宽度计算的更多相关文章

  1. SQL开发技巧(二)

    本系列文章旨在收集在开发过程中遇到的一些常用的SQL语句,然后整理归档,本系列文章基于SQLServer系列,且版本为SQLServer2005及以上-- 文章系列目录 SQL开发技巧(一) SQL开 ...

  2. SQL开发技巧(二) 【转】感觉他写的很好

    本文转自: http://www.cnblogs.com/marvin/p/DevelopSQLSkill_2.html 本系列文章旨在收集在开发过程中遇到的一些常用的SQL语句,然后整理归档,本系列 ...

  3. 如何让elemengUI中的表格组件相同内容的单元格自动合并

    1. 前言 这两天在工作中遇到这样一个需求:将某个Excel中的数据在页面上以表格形式展示出来,并且尽量保持数据层级与Excel中一致.在原始Excel文件中,对每一行相同的数据都进行了合并,使得数据 ...

  4. 关于html表格单元格宽度的计算规则

    * { margin: 0; padding: 0 } body { background: #fafafa } ul,li { list-style: none } h1 { margin: 20p ...

  5. 请教 JTable 里的单元格如何使得双击进入单元格后,单元格的内容处于全选中状态

    http://bbs.csdn.net/topics/390195204 ———————————————————————————————————————— java 达人, 最近在开发一个 java  ...

  6. 使用js合并table中的单元格

    用primefaces做的报表,领导要求合并相同内容的单元格,但是primefaces没有找到可以合并单元格的组件,想来想去,只有页面加载后用js合并了. http://blog.csdn.net/d ...

  7. colgroup中col定义表格单元格宽度

    colgroup中可以使用col来定义表格单元格宽度,可以使用像素(数字),百分比,我们来具体看看有什么不同. 先看一个最基本的:用像素(数字)表示,因为table有个宽度,这里表示占比 <ht ...

  8. 提高你css技能的css开发技巧(转载)

    一.resize实现图片对比 resize的语法如下: resize:none | both | horizontal | vertical 案例效果如下图 (鼠标移到左下角白色区域,往右侧拖动,实现 ...

  9. 用css样式,为表格加入边框

    Table 表格在没有添加 css 样式之前,是没有边框的.这样不便于我们后期合并单元格知识点的讲解,所以在这一节中我们为表格添加一些样式,为它添加边框. 在右侧代码编辑器中添加如下代码: <s ...

随机推荐

  1. Linux 定时实行一次任务命令

    当我们想在指定的时间自动执行 一次 任务的时候,可以使用at命令 启动服务 使用时首先检查atq的服务是否启动 service atd status # 检查atd的状态 service atd st ...

  2. JVM 理解性学习(二)

    1.G1 垃圾回收器 G1 能更少的 "Stop the World" ,能同时对新生代老年代进行垃圾回收. G1 将 Java 堆内存拆分为多个大小相等的 Region,并且新生 ...

  3. js实现表单的隔行换色、鼠标高亮出来等相关内容以及相关事件的作用

    主要是使用的onload().onmouseover和onmouseout的相关应用,满足此次的相关操作. 具体的相关的两个代码如下: <!DOCTYPE html> <html&g ...

  4. Javascript 获取随机颜色的几种方式

    先认识一下颜色值的表达方式 #FFFFFF,由6位16进制数组成.#FFFFFFFF,由8位16进制数组成,前6位表示颜色,后两位数表示透明度,数值越大,透明度越小.rgb(255,255,255), ...

  5. Flask 入门(十)

    flask 中的 db.relationship() 上文提到的方法,也可以找到狗的主人,但是,方便吗?,如果一个人有多只狗呢? 承接上文,修改main.py中的代码如下: #encoding:utf ...

  6. python3(十九)Partial func

    # 偏函数(Partial function) # 如int()函数可以把字符串转换为整数,当仅传入字符串时,int()函数默认按十进制转换 # 但int()函数还提供额外的base参数,默认值为10 ...

  7. tf.train.GradientDescentOptimizer 优化器

    tf.train.GradientDescentOptimizer(learning_rate, use_locking=False,name='GradientDescent') 参数: learn ...

  8. 【python实现卷积神经网络】批量归一化层实现

    代码来源:https://github.com/eriklindernoren/ML-From-Scratch 卷积神经网络中卷积层Conv2D(带stride.padding)的具体实现:https ...

  9. myvue 模拟vue核心原理

    // js部分index.js class Myvue{ constructor(options){ this.data = options.data; this.dep = new Dep(); v ...

  10. 千亿级平台技术架构:为了支撑高并发,我把身份证存到了JS里

    @ 目录 一.用户信息安全规范 1.1 ​用户信息.敏感信息定义及判断依据 1.1.1 个人信息 1.1.2 个人敏感信息 1.2 ​用户信息存储的注意事项 二.​框架技术实现 2.1 用户敏感信息自 ...