CSS 布局
近日开发中,总感觉页面布局方面力不从心。以前也曾学过这方面的内容,但是不够系统,因此我打算整理一下。
在web 页面中一般有 table 和 css+div 两种布局方式。
其中css+div 又分为原生css 和css 框架 两种。
现在一般网站已经不再使用table布局,但是一些简单对齐的页面也可以使用一下,因此在此处做一个简单的总结。
一、table 布局
html 标签中 跟table 布局相关的标签 有 <table> <th> <tr> <td>,另有两个比较重要的属性 是 rowspan,colspan。
table 布局也非常强大,在css 出现之前,所有的网页几乎都是用table 布局的。但是现在几乎不再使用了。以前看过的一话转载在此处:
为什么我们不建议用Table布局
Table要比其它html标记占更多的字节。
(延迟下载时间,占用服务器更多的流量资源。)
Tablle会阻挡浏览器渲染引擎的渲染顺序。
(会延迟页面的生成速度,让用户等待更久的时间。)
Table里显示图片时需要你把单个、有逻辑性的图片切成多个图。
(增加设计的复杂度,增加页面加载时间,增加HTTP会话数。)
在某些浏览器中Table里的文字的拷贝会出现问题。
(这会让用户不悦。)
Table会影响其内部的某些布局属性的生效(比如<td>里的元素的height:100%)
(这会限制你页面设计的自由性。)
一旦学了CSS知识,你会发现使用table做页面布局会变得更麻烦。
(先花时间学一些CSS知识,会省去你以后大量的时间。)
table对对于页面布局来说,从语义上看是不正确的。
(它描述的是表现,而不是内容。)
table代码会让阅读者抓狂。
(不但无法利用CSS,而且会你不知所云)
table一旦设计完成就变成死的,很难通过CSS让它展现新的面貌。
(你看过CSS Zen Garden吗?) Tables的好处 在某些场合,使用Table是100%的适合、恰当和正确。比如,用table做表格是完全正确的。 如果你无法判断是否应该使用table,参考一下上面的几条,相信你能找到答案。 英文:Why Tables Are Bad.
译文:webhek
table 布局需要使用table 标签把一块区域圈起来 ,化为布局区域,可以指定大小等,页面的内容应该放在<td> 标签内。
代码1:
<table width="500" height="500" border="1">
<tr>
<td>
这是一个table 布局
</td>
</tr>
</table>
代码1就在页面上布置了一个单元格,显示在了页面左上角。
如果我想把页面居中显示怎么办呢?方法就是在外层嵌套一个table ,然后把这个table 放在外层table 的td 单元格中,设置单元格对齐样式为居中。
代码2:
<table width="100%" border="1">
<tr>
<td align="center" valign="middle">
<table width="500" height="500" border="1">
<tr>
<td>
这是使用table 布局。
</td>
</tr>
</table>
</td>
</tr>
</table>
另外一个常用的就是合并单元格:包括横着合并和竖着合并。使用colspan 和rowspan 实现。
代码3:
<table width="100%" border="1">
<tr>
<td align="center" valign="middle" >
<table width="300" height="300" border="1">
<tr>
<td colspan="2">
这是使用table 布局。
</td>
<td>
这是使用table 布局。
</td>
</tr>
<tr>
<td>
这是使用table 布局。
</td>
<td rowspan="2">
这是使用table 布局。
</td>
<td>
这是使用table 布局。
</td>
</tr>
<tr>
<td>
这是使用table 布局。
</td>
<td>
这是使用table 布局。
</td>
</tr>
</table>
</td>
</tr>
</table>
colspan="2"指定了该单元格占两列位置。
rowspan="2" 指定了该单元格占两行位置。
经过上面代码扩展,现在的表格布局效果如下图所示:
基本上复杂布局就靠表格之间的嵌套来实现,最复杂的布局甚至要几十个table 来嵌套完成。
另外表格还有很多属性和标签,设置不同的属性就能达到想要的效果。
下一篇介绍css 布局。
CSS 布局的更多相关文章
- 界面设计技法之css布局
css布局之于页面就如同ECMAScript之于JS一般,细想一番,html就如同语文,css就如同数学,js呢,就是物理,有些扯远,这里就先不展开了. 回到主题,从最开始的css到如今的sass(l ...
- CSS布局 - 三栏布局
CSS布局技术可谓是前端技术中最基础的技术,就是因为基础,所以我认为要更加熟练,深入的去掌握,去梳理. 一. 传统 ---> 浮动实现的三栏布局 采用浮动实现的三栏布局有以下特点及注意事项: · ...
- DIV+CSS布局中主要CSS属性介绍
Float: Float属性是DIV+CSS布局中最基本也是最常用的属性,用于实现多列功能,我们知道<div>标签默认一行只能显示一个,而使用Float属性可以实现一行显示多个div的功能 ...
- CSS布局经典—圣杯布局与双飞翼布局
在我之前的博客网页整体布局完全剖析-剖完你不进来看一下么?中总结单列.两列.三列固宽与变宽布局,我还以为已经囊括了所有经典的网页布局方法了呢,当然除了CSS3的弹性盒模型没有涉及到,现在看来确实是自己 ...
- html学习第三天—— 第12章——css布局模型
清楚了CSS 盒模型的基本概念. 盒模型类型, 我们就可以深入探讨网页布局的基本模型了.布局模型与盒模型一样都是 CSS 最基本. 最核心的概念. 但布局模型是建立在盒模型基础之上,又不同于我们常说的 ...
- CSS篇之DIV+CSS布局
<div></div> div与其他标签一样,也是一个XHTML所支持的标签. div是XHTML中指定的,远门用于布局设计的容器标记. 简单的CSS布局 头部 内容 页脚 & ...
- CSS 布局口诀
body { font-family: Segoe UI,"Microsoft YaHei", Georgia,Helvetica,Arial,sans-serif,宋体, PMi ...
- CSS布局基础——BFC
what's BFC? 第一次看到这个名词,我是拒绝的,css什么时候还有这个东西?于是迫不及待的google了一下,才发现原来它无时无刻不在我们的css当中,只不过它并不是一个属性,不需要我们平常使 ...
- 熟悉HTML CSS布局模型
HTML最难的地方来了!这个我反复了很多遍, 包括现在写博客, 也对我自己算是一种温习, 我这块怕是没办法写的很好懂, 因为我自己还不能把我学到的准确通俗易懂的表达出来, 给自己记个笔记, 以后再来一 ...
随机推荐
- 【原创】自己动手写控件----XSmartNote控件
一.前面的话 在上一篇博文自己动手写工具----XSmartNote [Beta 3.0]中,用到了若干个自定义控件,其中包含用于显示Note内容的简单的Label扩展控件,用于展示标签内容的labe ...
- UP Board 网络设置一本通
前言 原创文章,转载引用务必注明链接,水平有限,欢迎指正. 本文环境:ubilinux 3.0 on UP Board 本文使用Markdown写成,为获得更好的阅读体验和正常的图片.链接,请访问我的 ...
- Swift中的可选链与内存管理(干货系列)
干货之前:补充一下可选链(optional chain) class A { var p: B? } class B { var p: C? } class C { func cm() -> S ...
- 移动web页面前端开发总结
移动web在当今的发展速度是一日千里,作为移动领域的门外汉,在这段时间的接触后,发现前端开发这一块做一个小小的总结. 1.四大浏览器内核 1.Trident (IE浏览器) :因为在早期IE占有大量的 ...
- WCF学习第二篇:WCF 配置架构。这有助于对wcf配置的理解和记忆
使用 Windows Communication Foundation (WCF) 配置元素,您可以配置 WCF 服务和客户端应用程序. 可以使用配置编辑器工具 (SvcConfigEditor.ex ...
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Django 1.7 Tutorial 学习笔记
官方教程在这里 : Here 写在前面的废话:)) 以前学习新东西,第一想到的是找本入门教程,按照书上做一遍.现在看了各种网上的入门教程后,我觉得还是看官方Tutorial靠谱.书的弊端一说一大推 本 ...
- window server 2008配置FTP服务器550 Access is denied. 问题解决办法
如果你是按照网上的通用方法,在搭建FTP服务器的时候临时建了一个用户的话,那么这个用户是普通用户,你即便勾选了“读”“写”权限,那么再打开防火墙的情况下,你还是不能上传文件,只能下载.只需要登录到服务 ...
- label和input里面文字不对齐的解决方法!
测试了集中方法,发现不行.只能用专署标签解决这个问题. <fieldset> <legend>神光咨询后台管理登录</legend> <br /& ...
- discuz首页设置默认地址不带forum.php后缀的方法
最近在研究discuz,上传安装几部搞定,打开首页跳到含有"/forum.php"的网址,到管理中心改了好一会儿也没好.那么如何实现discuz首页设置不带forum.php后缀呢 ...