全部章节   >>>>


本章目录

8.1 表格布局

8.1.1 表格布局

8.2 流式布局

8.2.1 瀑布流布局

8.2.2 masonry 实现瀑布流布局

8.3 div 布局

8.3.1 上下结构

8.3.2 上中下结构

8.3.3 上导航中下结构

8.3.4 左窄右宽

8.4 div 高级

8.4.1 内容左中右

8.4.2 导航内容左中右

8.4.3 内容右窄左宽

8.4.4 内容左窄右宽

总结:


8.1 表格布局

8.1.1 表格布局

  • HTML5 的表格标签除了以网格形式显示数据以外,还可以被应用于对网页内容的布局。
  • 传统表格布局方式实际上利用了 table 标签所具有的无边框特性,因此可以将网页中的内容按版式划分放入表格的各单元格中,从而实现复杂的排版组合。

示例:

<body>
      <form>
            <table class="form_table">
	   <caption><b> 用户登录 </b></caption>
	   <col width="90px" /><col />
	   <tr><th> 用户名:</th>
	   <td><input type="text" name="admin_name" alt=" 请填写用户名 " /></td>
	   </tr><tr><th> 密码:</th>
	   <td><input type="password" name="password" alt=" 请填写密码 " /></td>
	   </tr><tr><th></th>
	   <td><input type="submit" value=" 登录 " /><input type="reset" value=" 取消 " />
	   </td>
	   </tr></table>
	</form>
</body>
<style type="text/css">
	.form_table {
		margin-top: 10px;  width: 300px;
	}
	.form_table th {
		color: #333333;    font-weight: bold;
		padding: 5px 8px 5px 0;
		text-align: right; 	  white-space: nowrap;
	}
	.form_table td {
		color: #717171;	 line-height: 200%;
		padding: 6px 0 5px 10px;  text-align: left;
	}
</style>

th里面的文本在一行显示

td里面内容左边对齐

8.2 流式布局

流式布局不受窗口宽度影响,使用百分比宽度来限定布局元素,这样可以根据客户端分辨率的大小来进行合理的显示。即从左到右对该容器中的控件进行布局,当一行不能容纳时自动换行。该布局是从左到右,然后从上到下

流式布局是默认的页面布局方式。流式布局用百分比来做,简单明了又实用。

8.2.1 瀑布流布局

瀑布流布局是流式布局的一种,是当下比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部。

示例:

<body>
	<h1> 流式布局 </h1>
	<img src="logo.jpg">
	<p>
	流式布局基本没有对文字图片信息的位置控制,它所遵从的是从左至右,然后从上到下的顺序
	</p>
</body>

8.2.2 masonry 实现瀑布流布局

masonry 是一个 javascript 插件,通过该插件可以轻松实现瀑布流布局,和 CSS float 的效果不太一样的地方在于 float 先水平排列,然后再垂直排列,使用 masonry 则垂直排列元素,然后将下一个元素放置到网格中的下一个开发区域。这种效果可以最小化处理 不同高度的元素在垂直方向的间隙。

示例:

<body>
	<div id="grid">
	<div class="grid-item a">
	</div>
	<div class="grid-item b">
	</div>
	......
	<div class="grid-item d">
	</div>
	<div class="grid-item e">
	</div>
	</div>
</body>
<style type="text/css">
#grid { width: 1000px;margin: 0 auto;}
.grid-item { width: 200px;float: left;}
.a { background: lightblue;height: 200px;}
.b { background: lightcoral; height: 300px;}
.c { background: lightgreen;height: 500px;}
.d { background: lightsalmon;height: 350px;}
.e { background: lightseagreen;height: 150px;}
</style>
<script src="masonry.pkgd.min.js"></script>
<script type="text/javascript">
	var msnry = new Masonry('#grid', {
		itemSelector: '.grid-item',
		columnWidth: 200
	});
</script>

8.3 div 布局

传统的表格排版是通过大小不一的表格和表格嵌套来定位排版网页内容,改用 CSS 排版后,就是通过由 CSS 定义的大小不一的盒子和盒子嵌套来编排网页。因为用这种方式排版的网页代码简洁,更新方便,能兼容更多的浏览器

CSS 的盒子模式div 排版的核心所在。

8.3.1 上下结构

上下结构布局的用处一般用来做背景图,外围是灰色的,当中页面的正文底是白色的,非常大气。这是最常见的,也是最简单的页面表现形式,头部放 Logo banner,下面是主体内容。

示例:

<body>
	<div id="container">		
		<div id="header">这是头部</div>	
		<div id="mainContent">
			<p>这是主体</p>
		</div>		
	</div>
</body>
<style type="text/css">
	body {font-family: Verdana;font-size: 14px;margin: 0;background: #E9E9E9;
	}			
	#container {margin: 0 auto;width: 900px;background: #FFFFFF;padding: 15px;	}		
	#header {height: 100px; background: #6cf; margin-bottom: 5px;
	}		
	#mainContent {height: 300px; background: #cff; margin-bottom: 5px;
	}			
</style>

8.3.2 上中下结构

上下结构也是一种常见的页面表现形式,头部放 Logo banner,中间是主体内容,尾部放版权等内容。

示例:

<body>
	<div id="container">		
		<div id="header">这是头部</div>	
		<div id="mainContent">
			<p>这是主体</p>
		</div>		
		<div id="footer">这是尾部</div>
	</div>
</body>
<style type="text/css">
	body { font-family: Verdana; font-size: 14px; margin: 0; background: #E9E9E9;	}			
	#container { margin: 0 auto; width: 900px; background: #FFFFFF; padding: 15px;	}		
	#header { height: 100px; background: #6cf; margin-bottom: 5px;	}
	#mainContent { height: 300px; background: #cff; margin-bottom: 5px;	}
	#footer { height: 60px; background: #6cf;}
</style>

8.3.3 上导航中下结构

一个标准的网站都有导航,这是最常用的页面表现形式。

示例:

<body>
	<div id="container">		
		<div id="header">这是头部</div>		
		<div id="menu">这是导航</div>		
		<div id="mainContent">
			<p>1列固定宽度居中+头部+导航+尾部</p>
		</div>		
		<div id="footer">这是尾部</div>
	</div>
</body>
<style type="text/css">
	body {font-family: Verdana;font-size: 14px;margin: 0;background: #E9E9E9;}		
	p {margin: 0;}	
	#container {margin: 0 auto;width: 900px;background: #FFFFFF;padding: 15px;}		
	#header {height: 100px;background: #6cf;margin-bottom: 5px;}			
	#menu {height: 30px;background: #09c;margin-bottom: 5px;line-height: 30px}			
	#mainContent {height: 300px;background: #cff;margin-bottom: 5px;}			
	#footer {height: 60px;background: #6cf;}
</style>

8.3.4 左窄右宽

div 左右布局是 CSS 中较为复杂的。

示例:

<body>
	<div id="container">		
		<div id="header">这是头部</div>		
		<div id="mainContent">
			<div id="sidebar">这是工具栏</div>			
			<div id="content">列固定宽度左窄右宽型+头部</div>
		</div>
	</div>
</body>
<style type="text/css">
	body {font-family: Verdana;font-size: 14px;margin: 0;}		
	#container {margin: 0 auto;width: 900px;}		
	#header {height: 100px;background: #6cf;margin-bottom: 5px;}		
	#mainContent {margin-bottom: 5px;}			
	#sidebar {float: left;width: 200px;height: 500px;background: #9ff;}
	#content {float: right;width: 695px;height: 500px;background: #cff;}
</style>

8.4 div 高级

8.4.1 内容左中右

内容左中右布局是 div 中较为复杂的 3 列并排居中布局。

示例:

<body>
	<div id="container">		
		<div id="header">这是头部</div>	
		<div id="mainContent">
			<div id="sidebar">这是左列</div>		
			<div id="sidebar2">这是右列</div>			
			<div id="content">3列固定宽度居中+头部</div>
		</div>
	</div>
</body>
<style type="text/css">
	body { font-family: Verdana;font-size: 14px;margin: 0;background: #E9E9E9;}		
	#container {margin: 0 auto;width: 900px;background: #FFFFFF;padding: 15px;}		
	#header {height: 100px;background: #6cf;margin-bottom: 5px;}		
	#mainContent {height: 300px;margin-bottom: 5px;}			
	#sidebar {float: left;width: 200px;height: 300px;background: #9ff;}		
	#sidebar2 {float: right;width: 200px;height: 300px;background: #9ff;}			
	#content {margin: 0 205px;height: 300px;background: #cff;}
</style>

8.4.2 导航内容左中右

导航内容左中右布局是 3 列并排居中配上头部和尾部,这是国外 BLOG 经常使用的格式。

示例:

<body>
	<div id="container">	
		<div id="header">这是头部</div>		
		<div id="menu">这是导航</div>	
		<div id="mainContent">
			<div id="sidebar">这是左列</div>			
			<div id="sidebar2">这是右列</div>		
			<div id="content">3列固定宽度居中+头部+尾部</div>
		</div>	
		<div id="footer">这是尾部</div>
	</div>
</body>
<style type="text/css">
	body {font-family: Verdana;font-size: 14px;margin: 0;background: #E9E9E9;}			
	#container {margin: 0 auto;width: 900px;background: #FFFFFF;padding: 15px;}		
	#header {height: 100px;background: #6cf;margin-bottom: 5px;}			
	#menu {height: 30px;background: #09c;margin-bottom: 5px;line-height: 30px;}			
	#mainContent {height: 300px;margin-bottom: 5px;}		
	#sidebar {float: left;width: 200px;height: 300px;background: #9ff;}			
	#sidebar2 {float: right;width: 200px;height: 300px;background: #9ff;}		
	#content {margin: 0 205px;height: 300px;background: #cff;}			
	#footer {height: 60px;background: #6cf;}
</style>

8.4.3 内容右窄左宽

示例:

<body>
	<div id="container">
		<div id="header">这是头部</div>
		<div class="clearfloat"></div>
		<div id="menu">这是导航</div>
		<div class="clearfloat"></div>
		<div id="mainContent">
			<div id="sidebar">这是侧边栏</div>
			<div id="content">2列右窄左宽、高度自适应+头部+导航+尾部</div>
		</div>
		<div class="clearfloat"></div>
		<div id="footer">这是尾部</div>
	</div>
</body>
<style type="text/css">
	body {font-family: Verdana;font-size: 14px;margin: 0;background: #E9E9E9;}
	.clearfloat {clear: both;height: 0;font-size: 1px;line-height: 0px;}
	#container {margin: 0 auto;width: 900px;background: #FFFFFF;padding: 15px;}	
	#header {height: 100px;background: #6cf;margin-bottom: 5px;}		
	#menu {height: 30px;background: #09c;margin-bottom: 5px;line-height: 30px}		
	#mainContent {}	
	#sidebar {float: right;width: 200px;background: #9ff;margin-bottom: 5px;}	
	#content {float: left;width: 695px;background: #cff;margin-bottom: 5px;}	
	#footer {height: 60px;background: #6cf;}
</style>

8.4.4 内容左窄右宽

示例:

<body>
	<div id="container">
		<div id="header">这是头部</div>
		<div class="clearfloat"></div>
		<div id="menu">这是导航</div>
		<div class="clearfloat"></div>
		<div id="mainContent">
			<div id="sidebar">这是侧边栏</div>
			<div id="content">
			2列左窄右宽高度自适应且未知高度底部平齐+头部+导航+尾部
			</div>
		</div>
		<div class="clearfloat"></div>
		<div id="footer">这是尾部</div>
	</div>
</body>
<style type="text/css">
	body {font-family: Verdana;font-size: 14px;margin: 0;background: #E9E9E9;}
	.clearfloat {clear: both;height: 0;font-size: 1px;line-height: 0px;}
	#container {margin: 0 auto;width: 900px;background: #FFFFFF;padding: 15px;}	
	#header {height: 100px;background: #6cf;margin-bottom: 5px;}		
	#menu {height: 30px;background: #09c;margin-bottom: 5px;line-height: 30px}		
	#mainContent {}	
	#sidebar {float: left;width: 200px;background: #9ff;margin-bottom: 5px;}	
	#content {float: right;width: 695px;background: #cff;margin-bottom: 5px;}	
	#footer {height: 60px;background: #6cf;}
</style>

总结:

  • 传统表格布局方式实际上利用了 table 标签所具有的无边框特性,因此可以将网页中的内容按版式划分放入表格的各单元格中,从而实现复杂的排版组合。
  • 表格布局一般设置的样式有table样式、th样式和td样式
  • 流式布局不受窗口宽度影响,流式布局使用百分比宽度来限定布局元素,这样可以根据客户端分辨率的大小来进行合理的显示。
  • div简单布局控制头部、导航、内容和脚部。
  • div复杂布局控制头部、导航、内容左边、内容中间、内容右边和脚部。

更多推荐

HTML网页设计基础笔记 • 【第8章 页面布局与规划】