文章教程

13.3.1DIV+CSS概述

9/17/2020 9:37:07 PM 人评论 次浏览

13.3 新闻发布系统页面布局的实现

WEB系统除了拥有强大的功能外,还应拥有美观大方的界面,在所有界面中,首页是一个网站的第一页,也是最重要的一页,它是网站所有信息的归类缩影,很多知名门户网站 YAHOO、MSN、网易、新浪和主流的WEB2.0网站,都有一个美观大方的首页。为了更快地加载页面,为了更好地提高页面设计效率,并在此基础上保持视觉的一致性,为了更好地被搜索引擎收录,很多大型网站使用DIV+CSS实现网页的布局。

13.3.1 DIV+CSS概述

DIV是一种为HTML文档内大块的内容提供结构和背景的元素,DIV的起始标签和结束标签之间的所有内容都是用来构成这个块的。DIV是一个块级元素,意味着它的内容自动地开始一个新行。CSS是Cascading Style Sheets(层叠样式表)的缩写,在标准网页设计中,CSS负责网页内容的表现,即用于控制网页的外观。

使用DIV+CSS的方式布局整个网页,网页的内容放在DIV中,内容的显示效果由CSS进行控制,从而实现浏览器端页面的内容与表现形式的分离。这样不仅可使维护网站的外观变得更加容易,而且还可以使HTML文档代码更加简练,缩短浏览器的加载时间。下面以制作新闻发布系统的首页为例,详细讲解其制作过程。

13.3.2 界面布局图

新闻发布系统首页的界面布局图如图13-9所示,该界面布局分为以下几个部分。

(1)body部分:对于任何HTML页面,页面内容显示在body中。

(2)container部分:在body中定义一个id值为container的DIV层,作为显示整个首页的容器,并将container的DIV层划分为上(header 层)、中(pagebody 层)、下(footer层)3个部分。

(3)顶部 header 部分:包含了上(menu层)、下(banner层)两个部分。

(4)menu 部分:定义了新闻发布系统需要显示的功能超链接,并将新闻发布系统的LOGO(logo.gif图片)作为背景。

(5)banner部分:只定义了一张背景图片banner.jpg。

(6 )内容 pagebody 部分:包含了左(sidebar层)、右(mainbody层)两个部分。

(7)侧边栏 sidebar部分:仅包含了 login层,而login层提供了用户登录表单。

(8 )主体 mainbody 部分:仅包含了mainfunction层,mainfunction层为整个页面提供了主功能显示区域。

(9)底部footer部分:定义了新闻发布系统的版权等信息。

figure_0317_0410
图13-9 新闻发布系统首页的界面布局图

13.3.3 使用DIV实现页面布局

在“C:\wamp\www\news”目录下创建index.php文件,写入如下HTML代码,在<body></body>标签对中写入DIV的嵌套结构实现上面的布局。

<html>

<head>

<title>

欢迎访问新闻发布系统!

</title>

<link rel="stylesheet" href="css/news.css" type="text/css">

</head>

<body>

<div id="container">

<div id="header">

<div id="menu">

</div>

<div id="banner">

</div>

</div>

<div id="pagebody">

<div id="sidebar">

<div id="login">

</div>

</div>

<div id="mainbody">

<div id="mainfunction">

</div>

</div>

</div>

<div id="footer">

<a href="">系统简介</a>

<a href="">联系方法</a>

<a href="">相关法律</a>

<a href="">举报违法信息</a>

<br><br>公司版权所有

</div>

</div>

</body>

</html>

index.php页面中的代码片段

<link rel="stylesheet" href="css/news.css" type="text/css">

负责将外部CSS样式表文件“导入”到index.php页面中。也可以将该代码片段修改为下面的代码片段完成相同的功能。

<style>

<!--

@import url(css/news.css);

-->

</style>

13.3.4 准备图片素材

先准备一张LOGO图片,由于LOGO图片颜色较少,一般使用GIF格式的图片,这样能使页面载入的速度更快。准备的LOGO图片为logo.gif图片,如图13-10所示(图像宽度为800像素,图像高度为74像素)。准备一张banner图片,由于banner图片中颜色较多,如果使用GIF格式颜色会有太大的损失,这里使用了 JPEG 格式。准备的 banner 图片为 banner.jpg 图片,如图13-11所示(图像宽度为778像素,图像高度为177像素)。将logo.gif和banner.jpg图片存放在“C:\wamp\www\news\images”目录下。

figure_0318_0411
图13-10 新闻发布系统LOGO
figure_0318_0412
图13-11 新闻发布系统banner

13.3.5 CSS热身

在“C:\wamp\www\news\css”目录下创建news.css文件,并写入如下CSS代码。打开浏览器,在地址栏中输入“http://localhost/news/”,可以看到首页的基本布局如图13-12所示。

body{

font:12px "宋体";

text-align:center;

margin:0px;

background-color:#FFF;

}

#container{

width:800px;

margin:0px auto;

}

#header{

width:800px;

margin:0px auto;

}

#menu{

width:800px;

height:74px;

margin:0px auto;

background:url("../images/logo.gif") no-repeat;

}

#banner{

width:778px;

height:177px;

margin:0px auto;

background:url('../images/banner.jpg') no-repeat;

}

#pagebody{

width:778px;

height:500px;

margin:0px auto;

}

#sidebar{

width:163px;

height:500px;

float:left;

background-color:#BDBDBD;

}

#login{

margin:10px 0px 0px 0px;

}

#mainbody{

text-align:left;

width:610px;

height:500px;

float:right;

background-color:#D8D8D8;

}

#mainfunction{

margin:10px 0px 0px 10px;

}

#footer{

width:778px;

height:40px;

margin:0px auto;

background-color:#FFCC00;

}

figure_0320_0413
图13-12 首页的基本布局

news.css代码说明如下。

font:12px "宋体":设置对象内的字体大小为12像素,字体为宋体。这里使用了字体设置的缩写格式,完整的CSS代码是:font-size:12px;font-family: "宋体";。

text-align:center:设置对象内的文字对齐方式为居中对齐。除此以外还可以将文字对齐方式设置为居左(left)和居右(right)。

margin:0px:设置对象的外边距为 0 像素。这里使用了外边距设置的缩写格式,完整的CSS代码是:margin-top:0px;margin-right:0px;margin-bottom:0px;ma rgin-left:0px或margin:0px 0px 0px 0px;。分别设置了上边距、右边距、下边距、左边距为0像素。如果使用 auto 则表示自动调整外边距,例如“margin:0pxauto;”设置上下外边距为0像素,左右外边距为自动调整,即对象水平方向居中显示。

padding属性:设置对象的内边距,依次为上边距、右边距、下边距、左边距(如图13-13所示),其属性值请参考margin。padding属性在IE浏览器和Firefox浏览器的表现不同,因此该属性应慎用。

figure_0320_0414
图13-13 padding属性

background-color:#FFF:设置对象的背景色为白色,#FFF颜色使用了缩写,完整的颜色格式是#FFFFFF。

width:800px:设置对象的宽度为800像素。

说明:header层的宽度由menu层的宽度决定,menu层的宽度由logo.gif图片的宽度决定;pagebody层和footer层的宽度设置为banner.jpg图片的宽度;sidebar层宽度与mainbody层宽度之和小于pagebody层宽度。

height:74px:设置对象的高度为74像素。

说明: header层的高度是menu层高度与banner层高度之和;menu层的高度由logo.gif图片的高度决定;banner层的高度由banner.jpg图片的高度决定;sidebar层的高度应该等于mainbody层的高度;pagebody层的高度由sidebar层的高度(或mainbody层的高度)决定。

background:url("../images/logo.gif") no-repeat:设置对象的背景图片为 logo.gif 图片并且不平铺。这里使用了背景设置的缩写格式(使用背景设置的缩写格式时,各属性值的位置可以任意)。

设置背景颜色时使用:background-color:transparent|color

参数值说明如下

xiao_1 transparent:指定背景色透明。

xiao_1 color:指定具体的背景颜色。

设置背景图片时使用:background-image:none|url(url)

参数值说明如下。

xiao_1 none:指定无背景图片。

xiao_1 url:使用绝对或相对地址指定背景图片。

设置背景图片的平铺方式时使用:background-repeat:repeat|no-repeat|repeat-x|repeat-y

参数值说明如下。

xiao_1 repeat:指定背景图片纵向和横向平铺。

xiao_1 no-repeat:指定背景图片不平铺。

xiao_1 repeat-x:指定背景图片横向平铺。

xiao_1 repeat-y:指定背景图片纵向平铺。

设置背景图片的是否固定时使用:background-attachment:scroll|fixed

参数值说明如下。

xiao_1 scroll:指定背景图片随对象内容滚动。

xiao_1 fixed:指定背景图片固定。

设置背景图片的位置时使用:background-position:position

参数值说明如下。

position:指定背景图片相对于对象的位置。该属性所包含的水平方向的值为left(居左)、center (居中)、right(居右)或具体数值(百分比或像素值),垂直方向的值为 bottom(底部)、middle (中间)、top(顶部)和具体数值(百分比或像素值),水平方向的值与垂直方向的值用空格隔开。此属性的默认值为“(0% 0%)”,表示背景图片位于对象的左上角。

color:#666:设置对象内文本的颜色。

align属性:设定文本、图像和表格的对齐方式。

float:left:设置一个页面元素相对于另一个页面元素的浮动,即控制页面元素之间的相对位置排列。float所包含的值有none(无浮动)、left(在左边浮动)和right(在右边浮动),默认值为none。float属性与align属性的作用相似,只是align属性只能设定文本、图像和表格的对齐方式,而float却可以设置任何页面元素的对齐方式。由于DIV是一个块级元素,这意味着它的内容自动地开始一个新行,通过使用float属性可以设置DIV之间左右对齐。由于pagebody层的宽度为778像素,而sidebar层和mainbody层的宽度之和163像素+610像素等于773像素,因此当sidebar层漂浮在pagebody层的左边(float:left;),mainbody层漂浮在pagebody层的右边(float:right;)时,sidebar和mainbody之间存在5像素的间隙。

13.3.6 header层的实现

完成新闻发布系统首页布局之后,就可以实现各DIV层了。这里首先制作header层,具体步骤如下。

第一步 制作menu层

menu层的制作步骤如下。

(1)将index.php页面中id等于menu的DIV层修改为下面的代码片段。

<div id="menu">

<ul>

<li><a href="">首页</a></li>

<li class="menudiv"></li>

<li><a href="">评论浏览</a></li>

<li class="menudiv"></li>

<li><a href="">分类浏览</a></li>

<li class="menudiv"></li>

<li><a href="">新闻发布</a></li>

<li class="menudiv"></li>

<li><a href="">添加分类</a></li>

<li class="menudiv"></li>

<li><a href="">设为首页</a></li>

</ul>

</div>

说明如下。

①<ul></ul>与<li></li>结合起来使用的效果是在页面中以项目符号“figure_0322_0415”以及项目列表的形式来显示信息。使用项目列表<li>实现菜单menu,可以方便对菜单menu定制样式。

② <li class="menudiv"></li>代码的功能是向菜单项中间插入一些形如“|”分隔样式。在CSS中设置该分隔样式时使用的语法为.menudiv{}。

(2)向news.css代码中写入下面的代码片段,设置menu层中项目符号以及项目列表的CSS样式。

#menu ul{

list-style:none;

}

#menu ul li{

float:left;

}

说明:由于<ul>标签包含在id="menu"的DIV层中,<ul>标签CSS的设置语法应该是#menuul{};如果<ul>标签包含在 class="menudiv"的 DIV 层中,该<ul>标签 CSS 的设置语法应该是.menudiv ul{}。

<ul>标签的CSS样式list-style:none:取消项目符号“figure_0323_0416”的显示。

<li >标签的CSS样式float:left:设置项目列表在同一行显示。

(3)在#menu ul li{}中加入下面的代码片段,使项目列表项之间产生 20 像素的距离(左:10像素,右:10像素)。

margin:0 10px;

(4)向#menu ul{}中加入下面的代码片段,将整个项目列表标签浮动到menu层的右边。

float:right;

(5)向#menu ul{}中加入下面的代码片段,设置<ul>项目列表的外边距。此时项目列表<ul>标签分别向下移动25像素、向左移动10像素。

margin:25px 10px 0px 0px;

(6)向news.css 样式表中添加下面的代码片段,向项目列表项间添加一条竖线“|”, 竖线的宽度为2像素,高度为28像素,背景颜色为灰色#999。

.menudiv{

width:2px;

height:28px;

background:#999;

}

(7)由于项目列表项的文字位于竖线“|”的顶部,向#menu ul li{}中添加下面的代码片段,设置项目列表项中文本行的高度,这里将文本行的高度设置为与竖线同样的高度。

line-height:28px;

(8)在news.css样式表中添加下面的代码片段,修改项目列表项中超链接的样式。

#menu ul li a:link,#menu ul li a:visited{

font-weight:bold;

color:#666;

text-decoration:none;

background-color:#efefef;

}

#menu ul li a:hover{

background:#666;

color:#fff;

}

说明如下。

① font-weight属性用于设置字体的加粗情况,属性值包括:normal(普通)、bold(加粗)、bolder(更粗)、lighter(更细)以及100、200、300、400、500、600、700、800和900。其中normal相当于400,bold相当于700。

② text-decoration属性用于设置文字修饰效果,属性值包括:none(无修饰)、underline(下划线)、overline(上划线)、line-through(删除线)和blink(闪烁)。

③ 在 CSS 样式中设置超链接的 CSS 样式时,a:link 用于设置超链接未被访问时的样式, a:visited用于设置超链接被访问后的样式,a:hover用于设置当鼠标指针悬停到超链接上时超链接的样式,a:active用于设置按下鼠标时超链接的样式。

figure_0324_0417设置超链接的CSS样式时,必须按a:link、a:visited、a:hover和a:active的顺序进行设置,否则可能出现预想不到的效果,记住它们的顺序是“LVHA”。

经过这些步骤的修改,完成了header层中menu层的CSS代码。

第2步制作banner层

前面已经使用CSS代码设置了banner层的宽度、高度、背景图片和外边距,这里再向#banner{}的CSS代码中添加下面的代码片段,向banner层中添加一条宽度为5像素,颜色为浅黄色的下边框(使用border-left、border-right和border-top可以设置对象的左边框、右边框和上边框)。

border-bottom:5px solid #EFEF00;

由于banner层的下边框的宽度为5像素,需要将banner层的高度修改为183像素(177像素+5像素)。此时header层的高度 = 74像素(menu层的高度)+ 183像素(banner层的高度)。

经过这些步骤的修改,完成了 header 层中 banner 层的 CSS 代码,此时首页的显示效果如图13-14所示。

figure_0324_0418
图13-14 新闻发布系统的header层

13.3.7 pagebody层的实现

将#pagebody{}的CSS代码中的代码片段:

margin:0px auto;

修改为:

margin:5px auto;

使得pagebody层与header层和footer层的上下间隔为5像素。

向#sidebar{}和#mainbody{}的CSS代码中分别添加CSS代码片段:

overflow:hidden;

这样当mainbody层或sidebar层中的页面内容过长时,可将过长部分自动隐藏,防止了内容过长时,撑破页面布局。

经过这些步骤的修改,完成了pagebody层中sidebar层与mainbody层的CSS代码。

13.3.8 footer层的实现

将#footer{}的CSS代码片段修改为如下代码。

#footer{

width:778px;

height:40px;

margin:0px auto;

background-color:#FFCC00;

padding:20px 0px 0px 0px;

font-weight:bolder;

}

上面的CSS代码增置了footer层的上内边距为20像素,字体为较粗显示。经过这些步骤的修改,完成了footer层的CSS代码。

向news.css代码中添加如下CSS代码,设置首页中超链接的CSS样式。

a:link,a:visited{

text-decoration:none;

}

a:hover{

background:#666;

color:#fff;

}

通过以上步骤的修改,基本实现了新闻发布系统的首页布局。

教程类别