第七章利用CSS和多媒体美化页面

7.1 CSS链接的美化
7.1.1.文字链接的美化
在HTMI5 中,<a></a >标签始终定义超链接,用于从一张页面链接到另一张页面。<a> 元素最重要的属性是 href 属性,它指示链接的目标,如果未设置href 属性,后续多个属性均无法使用,则只是超链接的占位符。

设计者为了改变这种最基本的超链接样式,利用前面章节所讲的伪类选择器,按照“a:link-→a: visited-→a: hover→a: active→”的顺序,设置不同的链接访问状态效果,为文本超链接添加复杂而多样的样式。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>示例7.1</title>
		<style type="text/css">
			#menu{
				text-align: center;
			}
			a{
				margin: 10px;
			}
			a:link{		/*链接未访问*/
				font-size: 20px;
			}
			a:hover{		/*鼠标悬停时*/
				font-size: 18px;
				color: red;
				text-decoration: overline underline;
			}
			a:active{		/*鼠标点击时*/
				font-size: 20px;
				color: green;
				text-decoration: none;
			}
		</style>
	</head>
	<body>
		<div id="menu">
			<h2>服务中心菜单栏</h2>
			<a href="#" target="_blank">加入我们</a>
			<a href="#" target="_blank">媒体报道</a>
			<a href="#" target="_blank">官方博客</a>
			<a href="#" target="_blank">帮助中心</a>
		</div>
	</body>
</html>

7.1.2.按钮链接的美化

为了让链接外观看起来更像按钮,会让链接加上不同的边框阴影和相同的背景颜色加以实现。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>示例7.2</title>
		<style type="text/css">
			#menu{
				text-align: center;
			}
			a{
				font-size: 20px;
				font-weight: 700;
				text-decoration: none;
				background-color: lightcyan;
				color: red;
				margin: 5px;
				padding: 10px 15px;
				border-radius: 30px;
			}
			a:link,a:visited{		/*链接未访问和访问后*/
				box-shadow: -5px -5px 10px black;
			}
			a:hover{		/*鼠标悬停时*/
				font-size: 26px;
			}
			a:active{		/*鼠标点击时*/
				font-size: 20px;
				box-shadow: 6px 6px 10px black;
			}
		</style>
	</head>
	<body>
		<div id="menu">
			<h2>服务中心菜单栏</h2>
			<a href="#" target="_blank">加入我们</a>
			<a href="#" target="_blank">媒体报道</a>
			<a href="#" target="_blank">官方博客</a>
			<a href="#" target="_blank">帮助中心</a>
		</div>
	</body>
</html>

7.1.3背景链接的美化

为链接设置不同的背景颜色或者背景图片。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>示例7.3</title>
		<style type="text/css">
			#menu{
				text-align: center;
			}
			a{
				font-size: 20px;
				text-decoration: none;
				padding: 10px 15px;
				margin: -3px;
			}
			a:link,a:visited{		/*链接未访问和访问后*/
				background-color: lightgray;
				color: red;
			}
			a:hover{		/*鼠标悬停时*/
				background-color: brown;
				color: white;
			}
			a:active{		/*鼠标点击时*/
				font-weight: 700;
				color: lawngreen;
			}
		</style>
	</head>
	<body>
		<div id="menu">
			<h2>服务中心菜单栏</h2>
			<a href="#" target="_blank">加入我们</a>
			<a href="#" target="_blank">媒体报道</a>
			<a href="#" target="_blank">官方博客</a>
			<a href="#" target="_blank">帮助中心</a>
		</div>
	</body>
</html>

在示例7.3的基础上把链接未访问时和鼠标悬停时的背景颜色分别改为不同的背景图片。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>示例7.3</title>
		<style type="text/css">
			#menu{
				text-align: center;
			}
			a{
				font-size: 20px;
				text-decoration: none;
				padding: 10px 15px;
				margin: -3px;
			}
			a:link,a:visited{		/*链接未访问和访问后*/
				background-image: url(img/menu_1.jpg);
				color: red;
			}
			a:hover{		/*鼠标悬停时*/
				background-image: url(img/menu_2.jpg);
				color: white;
			}
			a:active{		/*鼠标点击时*/
				font-weight: 700;
				color: lawngreen;
			}
		</style>
	</head>
	<body>
		<div id="menu">
			<h2>服务中心菜单栏</h2>
			<a href="#" target="_blank">加入我们</a>
			<a href="#" target="_blank">媒体报道</a>
			<a href="#" target="_blank">官方博客</a>
			<a href="#" target="_blank">帮助中心</a>
		</div>
	</body>
</html>

7.2 CSS列表的美化

7.2.1.列表项类型(list-style-type)

此属性用来设置或检索对象的列表项所使用的标记类型。若 list-style-image 属性值为none 或指定url 地址的图片不能被显示时,此属性将发生作用。常用的list-style-type 属性值。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>CSS列表的美化</title>
		<style>
		.cs{
			list-style-type: square;
		}
		.hd{
			list-style-type: circle;
		}
		.qd{
			list-style-type: decimal;
		}
 
		</style>
	</head>
	<body>
		<div>
			<h3>测试工程师</h3>
			<ol class="cs">
				<li>李芳</li>
				<li>徐寒冰</li>
				<li>尹茹梦</li>
			</ol>
		</div>
		<div>
			<h3>后端开发工程师</h3>
			<ol class="hd">
				<li>刘昊</li>
				<li>刘准云</li>
				<li>张炳文</li>
			</ol>
		</div>
		<div>
			<h3>前端开发工程师</h3>
			<ol class="qd">
				<li>陈翔</li>
				<li>刘佳慧</li>
				<li>于璐</li>
			</ol>
		</div>
	</body>
</html>

7.2.2.列表项图像(list-style-image)

此属性用来设置或检索对象的刻表吹标记的图像。

		.cs{
			list-style-image: url(img/list1.jpg);
		}
		.hd{
			list-style-image: url(img/list2.jpg);
		}
		.qd{
			list-style-image: url(img/list3.jpg);
		}

7.2.3.列表项位置(list-style-position)

此属性用来设置对象的列表项标记相对于列表项内容的位置。

		li{
			border: 2px solid #000000;
			width: 100px;
		}
		.cs{
			list-style-image: url(img/list1.jpg);
			list-style-position: outside;
		}
		.hd{
			list-style-image: url(img/list2.jpg);
			list-style-position: inside;
		}
		.qd{
			list-style-image: url(img/list3.jpg);
		}

7.2.4.复合列表样式(list-style)
这个属性是设定列表项样式的一个快捷的综合写法。用这个属性可以同时设置列表项类型属性(lisl-style-type), 列表项图片属性(list-style-image) 和列表项位置属性(list-style-position)。
语法:list-style: list-style-type | list-style-position | list-style-image

			li{
				border: 2px solid #000000;
				width: 100px;
			}
			.cs{
				list-style-image: url(img/list1.jpg);
				list-style-position: outside;
			}
			.hd{
				list-style-image: url(img/list2.jpg);
				list-style-position: inside;
			}
			.qd{
				list-style-image: url(img/list3.jpg);
				list-style-position: inside;
			}
			.qd li{
				padding-left: 20px;
			}
			li{
				border: 2px solid #000000;
				width: 100px;
			}
			.cs{
				list-style: square url(img/list1.jpg) outside;
			}
			.hd{
				list-style: circle url(img/list2.jpg) inside;
			}
			.qd{
				list-style: decimal url(img/list3.jpg) inside;
			}
			.qd li{
				padding-left: 20px;
			}

7.2.5.利用背景图像实现列表项标记

虽然使用list-style-image 属性很容易实现设置列表项图像的目的,但这个属性不能够精确控制图像替换的项目符号距离文字的位置。因此,可以利用 background-image加以实现。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>示例7.8</title>
		<style type="text/css">
			li{
				background: url(img/list4.jpg) no-repeat;
				padding-left: 30px;
				height: 40px;
				list-style-type: none;
			}
		</style>
	</head>
	<body>
		<h3>快递公司</h3>
		<ol>
			<li>顺丰快递</li>
			<li>圆通快递</li>
			<li>中通快递</li>
			<li>韵达快递</li>
			<li>邮政快递</li>
		</ol>
	</body>
</html>

7.3 CSS表格的美化

7.3.1.border-collapse
border-collapse 属性设置表格的边框是否被合并为一个单一的边框,还是按照标准的HTML 中那样分开显示。
语法:border-collapse:separate I collapse I inherit
参数:separate 是默认值,边框分开不合并,不会忽略 border-spacing 和 empty-ells属
性。collapse 边框合并,如果相邻,则共用一个边框,会忽略 border-spacing 和 emply-eells 属性。Inherit 是从父元素继承值。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>示例7.9</title>
		<style type="text/css">
		table{
			/*默认值 单元格边框不合并*/
			/*border-collapse: separate;*/
			/*单元格边框合并*/
			border-collapse: collapse;
		}
		table,td,th{
			border: 1px solid black;
		}
		</style>
	</head>
	<body>
		<table>
		<tr>
			<th>课程</th><th>学分</th><th>考试形式</th>
		</tr>
		<tr>
			<td>SQL数据库技术</td><td>4.0</td><td>笔试</td>
		</tr>
		<tr>
			<td>PHP程序计算</td><td>6.0</td><td>机考</td>
		</tr>
		</table>
	</body>
</html>

7.3.2..border-spacing
border-spacing属性作用等同于标签属性 cellopacing,即当表格边框独立时(bondertlapse 属性等于 separate),相邻单元格边框之间的横向和纵向的间距。
语法:border-spacing:length
参数:length由数字和单位组成的长度值,不允许负值。如果提供全部两个lengh g期一个作用于横向间距,第二个作用于纵向间班。如果只据优一个mi 组时,这个值粉时作用于横向和纵向上的间距。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>示例7.10</title>
		<style type="text/css">
		.one{
			/*设置单元格的间距*/
			border-spacing: 10px;
		}
		.two{
			/*分别设置单元格横向和纵向的间距*/
			border-spacing: 10px 30px;
		}
		table,td{
			border: solid black;
		}
		</style>
	</head>
	<body>
		<table class="one">
			<tr>
				<td>大数据</td><td>物联网</td>
			</tr>
			<tr>
				<td>云计算</td><td>人工智能</td>
			</tr>
		</table>
		<table class="two">
			<tr>
				<td>大数据</td><td>物联网</td>
			</tr>
			<tr>
				<td>云计算</td><td>人工智能</td>
			</tr>
		</table>
	</body>
</html>

7.3.3.caption-side
caption-side 属性设置或检索表格标题在表格的哪一边,此属性必须和表格的 caption标签同时使用。
语法:caption-side: top I right I bottom I left
参数:top 是默认值,指定标题在表格上边。right 指定标题在表格右边。bottom 指定标题在表格下边。lelt 指定标题在表格左边。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>示例7.11</title>
		<style type="text/css">
			.cap{
				/*默认值 设置标题在表格上方*/
				/*caption-side: top;*/
				/*设置标题在表格下方*/
				caption-side: bottom;
			}
			table,th,td{
				border: 1px solid black;
			}
		</style>
	</head>
	<body>
		<table class="cap">
			<caption><h2>值班表</h2></caption>
			<tr>
				<th>时间</th><th>值日生</th>
			</tr>
			<tr>
				<th>08:00-12:00</th><th>张红敏</th>
			</tr>
			<tr>
				<th>14:00-17:00</th><th>李凯全</th>
			</tr>
			<tr>
				<th>19:00-22:00</th><th>曾天艺</th>
			</tr>
		</table>
	</body>
</html>

7.3.4.empty-cells
empty-cels属性设置或检索当表格的单元格无内容时,是否显示该单元格的边框。只有当表格边框独立时(即 border-collapse 属性等于 separate) 此属性才起作用。
语法:empty-cells:show I hide
参数:show是默认值,指定当表格的单元格无内容时,显示该单元格的边框。bide 指定当表格的单元格无内容时,隐藏该单元格的边框。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>示例7.12</title>
		<style type="text/css">
			.emp{
				/*默认值 空单元格有边框和背景*/
				/*empty-cells: show;*/
				/*空单元格没有边框和背景*/
				empty-cells: hide;
			}
			table,th,td{
				border: 1px solid black;
			}
		</style>
	</head>
	<body>
		<table class="emp">
			<tr>
				<th>有内容的单元格</th><th>有内容的单元格</th>
			</tr>
			<tr>
				<th>有内容的单元格</th><th></th>
			</tr>
			<tr>
				<th>有内容的单元格</th><th>有内容的单元格</th>
			</tr>
		</table>
	</body>
</html>

7.4 多媒体的添加与美化

7.4.1.<embed>标签的使用

利用<embed>标签可以在网页中插人各种类型的多媒体文件,如 WMV、MP3、AVM MP4、SWF、MOV、RMVB等。但是在使用<embed>标签之前,需要安装相应的插件,否则多媒体文件不能正常播放。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<h1>阳春三月</h1>
		<embed src="media/阳春三月.swf"></embed>
		<h1>第五空间</h1>
		<embed src="media/第五空间.mp4"></embed>
		<h1>听!是谁在唱歌</h1>
		<embed src="media/听!是谁在唱歌.mp3"></embed>
	</body>
</html>

7.4.2.<bgsound>标签的使用

<bgsound>是E浏览器中设置网页背景音乐的元索,利用它可以将音乐文件嵌人到网页中又不占页面空间,可以播放的声音文件格式包括 WAV、AU、MIDI、MP3等。<bgsound>标签参数设置不多。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<center>
			<h2>童话镇</h2>
			<embed  src="media/童话镇.mp3"></embed>
		</center>
	</body>
</html>

7.4.3.HTML5新增的多媒体标签
以前大多数音频、视频是通过插件(例如Flash) 来播放的,然而并非所有的测览器都拥有同样的插件。
HTMLS 新增了 audio 和 video 元素,分别用来插入声音和视频。至于格式,只要使用支持HTML5的浏览器就可以了,不需要使用其他的任何插件。<audio>和<video>标签的属性大致相同。

7.4.3.1.<audio>标签

		<h1>audio标签 铃铛</h1>
		<audio src="media/铃铛.wav" controls="controls"></audio>
		<h1>video标签 第五空间</h1>
		<video src="media/第五空间.mp4" controls="controls"></video>


7.4.3.2.<video>标签

		<h1>audio标签 铃铛</h1>
		<audio src="media/铃铛.wav" controls="controls"></audio>
		<h1>video标签 第五空间</h1>
		<video src="media/第五空间.mp4" controls="controls"></video>

7.5 综合案例——海洋旅游胜地

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>旅游海洋胜地</title>
		<style type="text/css">
			body{
				background-image: url(img/bg-0.jpg);
			}
			.all{
				margin: 0px auto;
				width: 700px;
				height: 600px;
				background-image: url(img/bg.jpg)
			}
			.top{
				width: 700px;
				height: 100px;
				background-image: url(img/top.jpg);
			}
			.menu{
				width: 700px;
				height: 60px;
				text-align: center;
			}
			.left,.right{
				width: 350px;
				height: 440px;
				float: left;
			}
			a{
				font-size: 13px;
				font-weight: 700;
				text-decoration: none;
				background-color: lightcyan;
				color: red;
				margin: 20px;
				padding: 10px 15px;
				border-radius: 10px;
			}
			a:link,a:visited{
				box-shadow: 6px 6px 10px black;
			}
			a:hover{
				font-size: 14px;
			}
			a:active{
				font-size: 13px;
				box-shadow: -5px -5px 10px black;
			}
			h3{
				color: brown;
			}
			ol{
				list-style-image: url(img/list2.jpg);
				list-style-type: upper-alpha;
			}
			table{
				border-collapse: separate;
				border-spacing: 20px;
			}
			p{
				text-indent: 2em;
				line-height: 22px;
				font-weight: 700;
				color: brown;
			}
		</style>
	</head>
	<body>
		<div class="all">
		<div class="top"></div>
		<div class="menu">
		<br>
			<a href="#" target="_blank">交通路况</a>
			<a href="#" target="_blank">娱乐设施</a>
			<a href="#" target="_blank">美食特产</a>
			<a href="#" target="_blank">历史文化</a>
			<a href="#" target="_blank">注意事项</a>
		</div>
		<div class="left">
			<h3>新闻动态</h3>
			<ol>
				<li>英比奥山顶景区</li>
				<li>新加坡空中缆车</li>
				<li>天际线斜坡滑车</li>
				<li>圣淘沙名胜世界</li>
				<li>海洋馆和水上探索乐园</li>
			</ol>
			<video src="media/movie.ogg" width="320px" height="250px" controls="controls"></video>
			
		</div>
		<div class="right">
			<table>
				<tr>
					<td><img src="img/table1.jpg"/></td>
					<td><img src="img/table2.jpg"/></td>
				</tr>
				<tr>
					<td><img src="img/table3.jpg"/></td>
					<td><img src="img/table4.jpg"/></td>
				</tr>
			</table>
			<p>这里不过是个平凡的小岛,岛上居民过着简单质朴的生活。当新加坡政府正式收回这个小岛时,决定将它改造成一个休闲度假的胜地</p>
			<br><br><br>
			<audio src="media/铃铛.mp3" controls="controls" loop="loop"></audio>
		</div>
		</div>
	</body>
</html>