【CSS】Table样式
一、table td的宽度详解
Table只有Table的宽度是可以设置的,并且各个浏览器理解一致
- 原则上应该将table的宽度设置成一个固定的值,而不应该设置成一个根据屏幕变化的值
- Table的宽度为600px,Table的td所有宽度总和不到600px,浏览器会自动按照td的宽度的比例算出宽度
<table style="width: 600px;border-collapse: collapse;border:1px solid" >
<tr>
<td style="width: 200px;">我是200px</td>
<td style="width: 200px;">我也是200px</td>
</tr>
</table>
运行结果:两个td都是300px;
- Table的宽度为600px,前两个td的宽度已经为600px,那么第三个td的宽度没有指定,这样的话第三个td的宽度是根据内容出现宽度的,然后前两个再按照比列计算、
前两个td小于table宽度,那么最后一个td就起到补全的作用
<table style="width: 600px;border-collapse: collapse;border:1px solid">
<tr>
<td style="width: 300px;">我是200px</td>
<td style="width: 300px;">我也是200px</td>
<td>我是根据内容的</td>
</tr>
</table>
- 如果一行文字太多,可以在<td>的样式中加入word-break: break-all(强制换行)
二、两个table水平并排显示
可以在外面再套个一行两列的大表格,左右两个单元格里再放表格
<table>
<tr>
<td><table>....</table><td>
<td><table>....</table><td>
<td><table>....</table></td> //同样可以设置一行3个表以上的
</tr>
</table>
三、Table中双虚线
<table border="0" cellpadding="0" cellspacing="0" style="width: 100%; border-collapse: collapse">
<tbody>
<tr>
<td style="border-bottom: black 3px double; width: 40%">
收費項目</td>
<td style="border-bottom: black 3px double; width: 20%">
價格</td>
<td style="border-bottom: black 2px double; width: 20%">
每日數量</td>
<td style="border-bottom: black 2px double;width: 20%">
港幣$</td>
</tr>
<!--StartHotelExpert--> <tr>
<td>
{FeeName}</td>
<td>
{Price}</td>
<td>
{Quantity}</td>
<td align="right">
{TotalPrice}</td>
</tr>
<!--EndHotelExpert--> <tr>
<td>
</td>
<td>
</td>
<td>
</td>
<td style="border-bottom: black 3px double; text-align: right; border-top: black 2px double">
<strong>{GrandTotal}</strong></td>
</tr>
</tbody>
</table>
在td中设置border,<td style="border-bottom: black 3px double; width: 40%">
注意:双虚线时需要设置为3px,而2px会叠在一起,没有效果。
四、Table中tr间距的设置
tr、td设置margin 无效;tr 设置padding无效、td设置padding有效
table中的tr的默认display:table-row,虽然可以修改为display:block但是就失去了tr特有的显示效果,如(td自动对齐);
解决方案:
css的两个属性:
border-collapse:collapse / separate
border-spacing:10px 10px; // 设置相邻单元格的边框间的距离(仅用于“边框分离”模式)
需要用border-collapse & border-spacing联合控制tr的间距.
- border-collapse 属性设置表格的边框是否被合并为一个单一的边框,还是象在标准的 HTML 中那样分开显示。
Separate: 默认值。边框会被分开。不会忽略 border-spacing 和 empty-cells 属性。
Collapse: 如果可能,边框会合并为一个单一的边框。会忽略 border-spacing 和empty-cells 属性。
- border-spacing: 该属性指定分隔边框模型中单元格边界之间的距离。在指定的两个长度值中,第一个是水平间隔,第二个是垂直间隔。除非 border-collapse 被设置为 separate,否则将忽略这个属性。尽管这个属性只应用于表,不过它可以由表中的所有元素继承。
如:<table style="border-collapse:separate; border-spacing:50px 10px;">
<tr></tr></table>
大致效果如下

五、Table中列太多支持左右滚动
<div id="divList" style="overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling: touch;width: 100%;">
<table class="CommonTable" id="orderlist" style="margin-bottom: 10px; left: 0;table-layout:fixed;">
white-space属性指定元素内的空白怎样处理:
nowrap:文本不会换行,文本会在在同一行上继续,直到遇到 <br> 标签为止。
overflow-x 属性规定是否对内容的左/右边缘进行裁剪 - 如果溢出元素内容区域的话:
auto:如果溢出框,则应该提供滚动机制。
table-layout属性用来显示表格单元格、行、列的算法规则:
默认是auto,可以改为fixe。
固定表格布局:
固定表格布局与自动表格布局相比,允许浏览器更快地对表格进行布局。
在固定表格布局中,水平布局仅取决于表格宽度、列宽度、表格边框宽度、单元格间距,而与单元格的内容无关。
通过使用固定表格布局,用户代理在接收到第一行后就可以显示表格。
自动表格布局:
在自动表格布局中,列的宽度是由列单元格中没有折行的最宽的内容设定的。
此算法有时会较慢,这是由于它需要在确定最终的布局之前访问表格中所有的内容。
【CSS】Table样式的更多相关文章
- css table样式
1.table样式首先设置表格边框,属性设置表格的边框是否被合并为一个单一的边框. table{ border-collapse: collapse; border-spacing: 0;} 2.固定 ...
- table完美css样式,table的基本样式,table样式
table完美css样式,table的基本样式,table样式 >>>>>>>>>>>>>>>>> ...
- css 设置table样式
<style type="text/css" > table tr td{height:39px; font-size: 13px; line-height: ...
- CSS div仿table样式
要想让div元素显示的样式与table相同,那么需要使用display属性,这个属性将告诉浏览器这些数据是制表的,将以哪种样式来渲染数据: // table --使该元素按table样式渲染 // t ...
- css初始化样式代码
为什么要初始化CSS? CSS初始化是指重设浏览器的样式.不同的浏览器默认的样式可能不尽相同,所以开发时的第一件事可能就是如何把它们统一.如果没对CSS初始化往往会出现浏览器之间的页面差异.每次新开发 ...
- CSS常用样式及示例
CSS常用样式及示例 一.简介 层叠样式表(英文全称:Cascading Style Sheets)是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集) ...
- CSS Reset样式重置
为了让页面在各不同浏览器之间显示效果一致,CSS样式清除和重置是前端开发必需要做的事情,结合前车之鉴,整理了份CSS重置样式代码供参考. @charset "utf-8"; /* ...
- CSS详细样式
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...
- 经常使用的两个清爽的table样式
两个我经常使用的table样式: <html> <head> <title></title> <style type="text/css ...
- CSS自学笔记(5):CSS的样式
CSS中拥有各种各样的样式表,而基本的样式有背景,文本,字体,链接,列表,表格,轮廓. 一.CSS-背景 CSS中允许用纯色背景,也允许用图片来创建复杂的个性背景. p {background-col ...
随机推荐
- 【LEETCODE】44、509. Fibonacci Number
package y2019.Algorithm.array; /** * @ProjectName: cutter-point * @Package: y2019.Algorithm.array * ...
- lmir 随笔
近期需要研究一些特征工程的工作,就打算把微软之前公布出来的特征都复现一遍,今天遇到的特征是 LMIR, 其实也就是language model for information retrieval的简写 ...
- UOJ348 WC2018 州区划分 状压DP、欧拉回路、子集卷积
传送门 应该都会判欧拉回路吧(雾 考虑状压DP:设\(W_i\)表示集合\(i\)的点的权值和,\(route_i\)表示点集\(i\)的导出子图中是否存在欧拉回路,\(f_i\)表示前若干个城市包含 ...
- ElasticSerach 6.x的安装及配置
1.准备工作 安装Centos7.建议内存2G以上.安装java1.8环境,固定IP地址,本文省略. 2.ElasticSerach单机安装 1) 创建/opt/es目录,存放文件ElasticSer ...
- GitHub预览网页[2019最新]
GitHub预览网页 1. 创建仓库 2. 设置页面预览 3. 上传html 4. 访问网页 1. 创建仓库 登陆GitHub创建仓库 datamoko 添加基本信息: 仓库名.仓库描述,然后点击创建 ...
- 安卓MediaPlayer框架之Binder机制
Binder简介 Binder是Android系统进程间通信的主要方式之一. 1.在ASOP中,Binder使用传统的C/S通信方式:即一个进程作为服务端提供诸如视音频解封装,解码渲染,地址查询等各种 ...
- uavcan扩展帧格式 zubax
zubax_gnss_1.0和zubax_gnss_2.0中使用的uavcan的两种不同封装方式.都是采用扩展帧29b帧类型 zubax_gnss_1.0 我的代码:https://github.co ...
- vue_插槽的理解和使用
对于插槽的概念和使用,这是vue的一个难点,这需要我们静下心来,慢慢研究.以下是我这两天通过官网和其他资料的学习和使用总结出来的笔记,如有错误或者有不同见解的,欢迎留言,一起学习. 什么是插槽? 插槽 ...
- 将集群WEB节点静态数据迁移到共享存储器(LNMP环境)
系统版本:Centos 6.5 机器及IP规划如下: 192.168.0.117 MySQL 192.168.0.118 nginx+php 192.168.0.123 nfs ①在NFS机器上 ...
- 学习python的日常6
错误.调试和测试: 错误处理: try: print('try...') r = 10 / 0 print('result:', r) except ZeroDivisionError as e: p ...