前言:

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

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. 完整微信小程序授权登录页面教程

    完整微信小程序授权登录页面教程 1.前言 微信官方对getUserInfo接口做了修改,授权窗口无法直接弹出,而取而代之是需要创建一个button,将其open-type属性绑定getUseInfo方 ...

  2. 从一个慢查询到MySQL字符集编码

    从一个慢查询到MySQL字符集编码 目录 从一个慢查询到MySQL字符集编码 1. 问题起源 2. MySQL字符集和字符集排序规则 2.1 字符集相关概念 2.2 MySQL中的字符集和字符集排序规 ...

  3. adb工作常用命令

    adb devices 查看手机名 adb shell链接手机 dumpsys window windows |grep -i current 打开软件,查看软件入口,和包名,白色为包名,红框为包入口 ...

  4. TC1.6SourceCode java课程表

    /** * @version 2.0 * @author sharks */ /** * Instruction * this version will use IO * apply file to ...

  5. LARAVEL快速入门

    一.查询 $map = []; $map[] = ['u.store_id','=',0]; $map[] = ['u.reg_time','<',time()]; $map[] = ['u.u ...

  6. 曹工说Redis源码(5)-- redis server 启动过程解析,以及EventLoop每次处理事件前的前置工作解析(下)

    曹工说Redis源码(5)-- redis server 启动过程解析,eventLoop处理事件前的准备工作(下) 文章导航 Redis源码系列的初衷,是帮助我们更好地理解Redis,更懂Redis ...

  7. 通过STC15F2K60S2控制SIM900A发中英文短信,打电话

    本文通过串口通信,使用STC15系列单片机实现发短信打电话功能. 一. 注意事项 1. 首先要确定手机卡已经注册到网络,具备打电话发短信功能 2. 正确的硬件连接: P3.0-----STXD或者5V ...

  8. bootstrapTable随机改变列颜色

    { title: '运单编号', field: 'waybillNumber', align: 'center', valign: 'middle', cellStyle: function (val ...

  9. IKAnalyzer修改支持lucene8.0

    源码已经上传GitHub. 如果直接使用jar:IKAnalyzer-5.0.2. 在这我只是在原有代码结构上做了微调,让代码支持lucene8.0.

  10. A - Chat Group Gym-101775A

    题目连接:https://codeforces.com/gym/101775/problem/A 题解:就是累加组合数 但是直接由K累加到N肯定会TLE ,所以我们不妨判断不能组成group的情况,即 ...