display:table布局总结
1. table布局方式

2. table布局实际应用
效果:
代码:
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
/*CSS Table*/
.table { display: table; }
.table-fixed { table-layout: fixed; }
.table-row { display: table-row; }
.table-cell { display: table-cell; }
.table-colgroup { display: table-column-group; }
.table-caption { display: table-caption; }
.table-col { display: table-column; }
.table-body { display: table-row-group; }
.table-header { display: table-header-group; }
.table-footer { display: table-footer-group; }
.table-vt { vertical-align: top; }
.table-vm { vertical-align: middle; }
.table-vb { vertical-align: bottom; }
/*CSS Table*/
html,
body { height: 100%;margin: 0; padding: 0; background: #333;}
div.demo1 { width: 100%;height: 200px; }
.box1 { background: #6D5CAE; }
.box2 { background: #48B0F7; }
.box3 { background: #10CFBD; }
h3 { padding-left: 20px;color: #fff; }
.demo2 { width: 400px;height: 300px;}
.demo2 div.table-header-group {padding: 5px 20px;background: #10CFBD;}
.demo2 .main {height: 100%;background: #48B0F7;}
.demo2 div.table-footer-group {padding: 5px 20px;background: #10CFBD;}
.demo3 {width: 400px;height: 300px;background: #10CFBD;}
.demo4 {width: 400px;height: 300px;background: #10CFBD;text-align: center;}
.center-box {width: 100px;height:100px;background: #6D5CAE;display: inline-block;}
.header{font-size:30px;} /*列表布局,等空隙*/
.grid {
display: table;
border-spacing: 4px;
}
.row {
display: table-row;
}
.image {
display: table-cell;
width: 240px;
height: 300px;
background-color: lightsalmon;
vertical-align: top;
text-align: center;
}
</style>
</head> <body>
<h3>子容器自动平分宽度(即使设置宽度,也会进行自动等分,自适应父容器的宽度)</h3>
<div class="table demo1">
<div class="box1 table-cell">1</div>
<div class="box2 table-cell">2</div>
<div class="box3 table-cell">3</div>
</div> <h3>垂直三行,中间自适应</h3>
<div class="table demo2">
<div class="header table-header-group">Table Header</div>
<div class="main table-row">自动占满剩余空间</div>
<div class="table-footer-group">Table Footer</div>
</div> <h3>垂直居中对齐</h3>
<div class="table demo3">
<div class="table-cell table-vm">
<div class="center-box">123</div>
</div>
</div> <h3>水平居中对齐</h3>
<div class="demo4" style="text-align:left;">
<div class="table" style="margin:0 auto">
<div class="center-box">123</div>
</div>
</div> <h3>水平居中对齐2</h3>
<div class="demo4" style="text-align:left;">
<span class="center-box table" style="margin:0 auto">123345678</span>
</div> <h3>列表布局,border-spacing实现等空隙</h3>
<div class="grid">
<div class="row">
<div class="image"></div>
<div class="image"></div>
<div class="image"></div>
</div>
<div class="row">
<div class="image"></div>
<div class="image"></div>
<div class="image"></div>
</div>
</div>
</body> </html>
3. table布局其他应用
1. 实现两端对齐布局,使用两个table-cell,分别text-align:left和text-align:right,由于要额外套两个容器,所以不是较好的方法
2. 实现等高布局,具体可以参考等高布局
3. 实现两栏自适应布局,具体可以参考自适应布局
4. table布局的注意点
1. display: table时padding会失效
2. display: table-row时margin、padding同时失效
3. display: table-cell时margin会失效,padding有效,高度有效
4. display: table-cell时float, position:absolute会失效,不用同时使用
参考:http://ghmagical.com/article/page/id/s1x7vzL6Z2Sz
https://blog.csdn.net/Xiaotongbiji/article/details/79851288
https://blog.csdn.net/Bessicxie/article/details/78572424
https://blog.csdn.net/Doulvme/article/details/79015264
https://blog.csdn.net/huangbaokang/article/details/82183084
display:table布局总结的更多相关文章
- [转]基于display:table的CSS布局
当IE8发布时,它将支持很多新的CSS display属性值,包括与表格相关的属性值:table.table-row和table-cell,它也是最后一款支持这些属性值的主流浏览器.它标志着复杂CSS ...
- CSS display:table属性用法- 轻松实现了三栏等高布局
display:table:此元素会作为块级表格来显示(类似 <table>); display:table-cell属性指让标签元素以表格单元格的形式呈现,类似于td标签.目前IE8+以 ...
- 基于CSS属性display:table的表格布局的使用
项目改造中遇到DIV+CSS实现的table,新需求需要在表格使用单元格合并,网上调查返现CSS display:table实现的table表格,没有单元格的属性和样式,经过一番思考,曲折现实了单元格 ...
- css Table布局:基于display:table的CSS布局
两种类型的表格布局 你有两种方式使用表格布局 -HTML Table(<table>标签)和CSS Table(display:table 等相关属性). HTML Table是指使用原生 ...
- 使用display:table使两栏布局高度相等
两栏布局大家应该经常用了,但是遇到坑爹的要两栏的高度对齐的话要怎么办呢? <!DOCTYPE html> <html> <head> <meta charse ...
- css display:table圣杯布局
圣杯布局指的是一个网页由页眉,3等高列(2个固定侧栏和中心内容主体)和贴在页面底部的页脚组成. 主要思路是对整个容器使用地上diaplay:table 的css规则,然后分别对页眉页脚使用displa ...
- 使用display:table来解决一些问题
一直有,多栏的需求,当然用table布局,很快就做完了.不怎么喜欢用table,刚开始使用display:table,但是有一条老是不能达到我的效果,那就是有一行不固定宽度的时候,就不知道怎么处理,今 ...
- css table 布局
使用CSS表格 CSS表格能够解决所有那些我们在使用绝对定位和浮动定位进行多列布局时所遇到的问题.例如,“display:table;”的CSS声明能够让一个HTML元素和它的子节点像table元素一 ...
- 记录display:table的使用
兼容性:不兼容IE7 1.左右对齐 <!DOCTYPE html> <html lang="en"> <head> <meta chars ...
随机推荐
- sessionStorage 和 localStorage
html5 中的 web Storage 包括了两种存储方式:sessionStorage 和 localStorage. sessionStorage 用于本地存储一个会话(session)中的数据 ...
- 在mininet上基于ovs,ovx,pox搭建三点虚拟网络
本次试验基于mininet平台,在平台中利用ovs新建1个交换机,以pox为控制器,ovx作为中间层实现虚拟化. 基础请参照http://ovx.onlab.us/getting-started/tu ...
- Oracle 事务 锁
一. 事务 是一系列的数据库操作,是数据库应用的基本逻辑单位以及并发控制的基本单位.所谓的事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位. 要将有组语句作为事务考 ...
- 洛谷P2468 [SDOI2010]粟粟的书架(二分答案 前缀和 主席树)
题意 题目链接 给出一个矩形,每个点都有一些值,每次询问一个子矩阵最少需要拿几个数才能构成给出的值 Sol 这题是真坑啊.. 首先出题人强行把两个题拼到了一起, 对于前$50 \%$的数据,考虑二分答 ...
- Java - 静态方法不具有多态性
class A1 { public static void f() { System.out.println("A1.f()"); }}class A2 extends A1 { ...
- 九、Linux 磁盘管理
Linux 磁盘管理 Linux磁盘管理好坏直接关系到整个系统的性能问题. Linux磁盘管理常用三个命令为df.du和fdisk. df:列出文件系统的整体磁盘使用量 du:检查磁盘空间使用量 fd ...
- Android 性能篇 -- 带你领略Android内存泄漏的前世今生
基础了解 什么是内存泄漏? 内存泄漏是当程序不再使用到的内存时,释放内存失败而产生了无用的内存消耗.内存泄漏并不是指物理上的内存消失,这里的内存泄漏是指由程序分配的内存但是由于程序逻辑错误而导致程序失 ...
- 关于request.getServletContext()方法报错的问题
可以通过修改pom文件来添加一个javax.servlet-api-3.1.0.jar的jar包,找到你的pom.xml文件添加代码如下: <dependency> <groupId ...
- 学习python第四天 列表
模块的导入是使用 import sys#导入模块sysprint(sys.path)#打印环境变量,可能存在的目录print(sys.argv)#打印脚本的名字,相对路径 import os os.s ...
- 什么是redis缓存穿透, 缓存雪崩, 缓存击穿
什么是redis? redis是一个非关系型数据库,相对于其他数据库而言,它的查询速度极快,且能承受的瞬时并发量非常的高.所以常常被用来存放网站的缓存,以减少主要数据库(如mysql)的服务器压力. ...