CSS布局基础

使用CSS布局首先要接触的一个知识点就是CSS的盒子模式,这就是DIV排版的核心所在,传统的表格排版是通过大小不一的表格和表格嵌套来定位排版网页内容,改用CSS排版后,就是通过由CSS定义的大小不一的盒子和盒子嵌套来编排网页。因为用这种方式排版的网页代码简洁,更新方便,能兼容更多的浏览器,比如PDA设备也能正常浏览。

理解CSS盒子模型

什么是CSS的盒子模式呢?为什么叫它是盒子?先说说我们在网页设计中常听的属性名:内容(content)、填充(padding)、边框(border)、边界(margin), CSS盒子模式都具备这些属性。

传统的前台网页设计是这样进行的:根据要求,先考虑好主色调,要用什么类型的图片,用什么字体、颜色等等,然后再用Photoshop这类软件自由的画出来,最后再切成小图,通过设计HTML生成页面,改用CSS排版后,我们要转变这个思想,此时我们主要考虑的是页面内容的语义和结构,因为一个强CSS控制的网页,等做好网页后,你还可以轻松的调你想要的网页风格,况且CSS排版的另外一个目的是让代码易读,区块分明,强化代码重用,所以结构很重要。如果你想说我的网页设计的很复杂,到后来能不能实现那样的效果?我要告诉你的是,如果用CSS实现不了的效果,一般用表格也是很难实现的,因为CSS的控制能力实在是太强大了,顺便说一点的是用CSS排版有一个很实用的好处是,如果你是接单做网站的,如果你用了CSS排版网页,做到后来客户有什么不满意,特别是色调的话,那么改起来就相当容易,甚至你还可以定制几种风格的CSS文件供客户选择,又或者写一个程序实现动态调用,让网站具有动态改变风格的功能。

实现结构与表现分离

结构和表现相分离是用CSS布局的特色所在,结构与表现分离后,代码简洁,方便更新,举个例来说P是结构化标签,有P标签的地方表示这是一个段落区块,margin是表现属性,要让一个段落右缩进2字高,有些人会想到加空格,然后不断地加空格,但现在可以给P标签指定一个CSS样式:P {text-indent: 2em;},这样结果body内容部分就如下,这没有外加任何表现控制的标签:

<p>子(前551年9月28日~前479年4月11日)名丘,字仲尼,春秋末期鲁国人,汉族。英文:Confucius, Kung Tze 。中国古代伟大的思想家、政治家、教育家,儒家学派创始人,世界文化名人。孔子的言行思想主要载于语录体散文集《论语》及《四书》中。</p>

如果还要对这个段落加上字体、字号、背景、行距等修饰,直接把对应的CSS加进P样式里就行了,不用像这样来写了:

<p><font color="#FF0000" face="宋体">段落内容</font></p>

这个是结构和表现混合一起写的,如果很多段落有统一结构和表现的话,再这样累加写下去代码就繁冗了,而采用以下内容和表现分离的写法:
<style type="text/css">
<!--

p {

font-size: 14pt;

font-style: normal;

line-height: 28px;

color: #663333;

background-color: #DDDDDD;

font-family: "华文楷体";

}
-->
</style>
</head>
<body >
<p>孔子(前551年9月28日~前479年4月11日)名丘,字仲尼,春秋末期鲁国人,汉族。英文:Confucius, Kung Tze 。中国古代伟大的思想家、政治家、教育家,儒家学派创始人,世界文化名人。孔子的言行思想主要载于语录体散文集《论语》及《四书》中。
</p>

以下一段代码可以加深理解结构和表现相分离:

用CSS排版

<style type="text/css">

<!--

#photoList img{

  height:80;

  width:100;

  margin:5px auto;

}

-->

</style>

<div id="photoList">

    <img src="01.jpg" />

    <img src="02.jpg" />

    <img src="03.jpg" />

    <img src="04.jpg" />

    <img src="05.jpg" />

</div>

第一种方法是结构表现相分离,内容部分代码简单吧,如果还有更多的图片列表的话,那么第一种CSS布局方法就更有优势,打个比喻你好理解:我在BODY向你介绍一个人,我只对你说他是一个人,至于他是一个什么样的人,有多高,是男是女,你去CSS那里查下就知道。这样我在BODY的工作就简单了,也就是说BODY的代码就简单了。如果BODY有一个团队人在那里,我在CSS记录一项就行了,这有点像Flash软件里的元件和实例的概念,不同的实例共享同一个元件,这样动画文件就不大了,把这种想法移到CSS网页设计中,就是代码不复杂,网页文件体积小能较快被客户端下载了。

用CSS排版减小网页文件体积

像上面我做的那个版面,一共分为四个区块,每个区块的框架是一样的,这个框架就是用CSS写出来的,样式写一次,就可以被无数次调用了(用CLASS调用,而不是ID),只要改变其中的文字内容就可以生成风格统一的众多板块了,它的样式和结构代码是:

<style type="text/css">

<!--

* {margin:0px; padding:0px;}

body {

font-size:12pt;

margin:0px auto;

height: auto;

width: 805px;

}

.mainBox {

border: 1px dashed #0099CC;

 margin: 3px;

padding: 0px;

float: left;

height: 300px;

width: 192px;

}

.mainBox h3 {

float: left;

height: 20px;

width: 179px;

color: #FFFFFF;

padding: 6px 3px 3px 10px;

background-color: #0099CC;

font-size: 16pt;

}

.mainBox p {

line-height: 1.5em;

text-indent: 2em;

margin: 35px 5px 5px 5px;

}

-->

</style>

<div class="mainBox"> <h3>前言</h3> <p>正文内容</p> </div>

<div class="mainBox"> <h3>CSS盒子模式</h3> <p>正文内容 </p> </div>

<div class="mainBox"> <h3>转变思想</h3> <p>正文内容 </p> </div>

<div class="mainBox"> <h3>熟悉步骤</h3> <p>正文内容 </p> </div>

实例效果

【返回】

熟悉工作流程

在真正开始工作之前我们脑海中要形成这样一种思想:表格是什么我不知道,在内容部分我不能让它再出现表现控制标签,如:font、color、height、width、align等标签不能再出现,(简单说工作前先洗脑,忘掉以前的一惯做法,去接受和使用全新的方法),我不是单纯的用DIV来实现排版的嵌套,DIV是块级元素,而像P也是块级元素,例如要分出几个文字内容块,不是一定要用DIV才叫DIV排版,不是“<div>文字块一</div><div>文字块二</div><div>文字块三</div>”,而用“<p>文字块一</p><p>文字块二</p><p>文字块三</p>”更合适。

用DIV+CSS设计思路是这样的:

1.用div来定义语义结构;

2.然后用CSS来美化网页,如加入背景、线条边框、对齐属性等;

3.最后在这个CSS定义的盒子内加上内容,如文字、图片等(没有表现属性的标签),下面大家跟我一起来做一个实例加深对这个步骤的理解。先看结果图:

DIV来定义语义结构

现在我要给大家演示的是一个典型的版面分栏结构,即页头、导航栏、内容、版权(如下图)

其结构代码如下:

<div id="header">此处显示 id "header" 的内容</div>

<div id="nav">此处显示 id "nav" 的内容</div>

<div id="content">此处显示 id "content" 的内容</div>

<div id="footer">此处显示 id "footer" 的内容</div>

上面我们定义了四个盒子,按照我们想要的结果是,我们要让这些盒子等宽,并从下到下整齐排列,然后在整个页面中居中对齐,为了方便控制,我们再把这四个盒子装进一个更大的盒子,这个盒子就是BODY,这样代码就变成:

<body>

<div id="header">此处显示 id "header" 的内容</div>

<div id="nav">此处显示 id "nav" 的内容</div>

<div id="content">此处显示 id "content" 的内容</div>

<div id="footer">此处显示 id "footer" 的内容</div>

</body>

CSS来美化网页

最外边的大盒子(装着小盒子的大盒子)我们要让它在页面居中,并重定义其宽度为760像素,同时加上边框,那么它的样式是:

body {

font-family: Arial, Helvetica, sans-serif;

font-size: 10pt;

margin: 0px auto;

height: auto;

width: 760px;

border: 1px solid #006633;

}

页头为了简单起见,我们这里只要让它整个区块应用一幅背景图就行了,并在其下边界设计定一定间隙,目的是让页头的图像不要和下面要做的导航栏连在一起,这样也是为了美观。其样式代码为:

#header {

height: 100px;

width: 760px;

background-image: url(headPic.gif);

background-repeat: no-repeat;

margin:0px 0px 3px 0px;

}

导航栏我做成像一个个小按钮,鼠标移上去会改变按钮背景色和字体色,那么这些小小的按钮我们又可以理解为小盒子,如此一来这是一个盒子嵌套问题了,样式代码如下:

#nav {

height: 25px;

width: 760px;

font-size: 12pt;

list-style-type: none;

}

#nav li {

float:left;

}

#nav li a{

color:#000000;

text-decoration:none;

padding-top:4px;

display:block;

width:97px;

height:22px;

text-align:center;

background-color: #009966;

margin-left:2px;

}

#nav li a:hover{

background-color:#006633;

color:#FFFFFF;

}

内容部分主要放入文章内容,有标题和段落,标题加粗,为了规范化,我用H标签,段落要自动实现首行缩进2个字,同时所有内容看起来要和外层大盒子边框有一定距离,这里用填充。内容区块样式代码为:

#content {

height:auto;

width: 740px;

line-height: 1.5em;

padding: 10px;

}

#content p {

text-indent: 2em;

}

#content h3 {

font-size: 16pt;

margin: 10px;

}

版权栏,给它加个背景,与页头相映,里面文字要自动居中对齐,有多行内容时,行间距合适,这里的链接样式也可以单独指定,我这里就不做了。其样式代码如下:

#footer {

height: 50px;

width: 740px;

line-height: 2em;

text-align: center;

background-color: #009966;

padding: 10px;

}

最后回到样式开头大家会看到这样的样式代码: * { margin: 0px; padding: 0px; } 这是用了通配符初始化各标签边界和填充,(因为有部分标签默认会有一定的边界,如Form标签)那么接下来就不用对每个标签再加以这样的控制,这可以在一定程度上简化代码。最终完成全部样式代码是这样的:

<style type="text/css">

<!--

* { margin: 0px; padding: 0px; }

body {

font-family: Arial, Helvetica, sans-serif;

font-size: 10pt;

margin: 0px auto;

height: auto;

width: 760px;

border: 1px solid #006633;

}

#header {

height: 100px;

width: 760px;

background-image: url(headPic.gif);

background-repeat: no-repeat;

margin:0px 0px 3px 0px;

}

#nav {

height: 25px;

width: 760px;

font-size: 12pt;

list-style-type: none;

}

#nav li {

float:left;

}

#nav li a{

color:#000000;

text-decoration:none;

padding-top:4px;

display:block;

width:97px;

height:22px;

text-align:center;

background-color: #009966;

margin-left:2px;

}

#nav li a:hover{

background-color:#006633;

color:#FFFFFF;

}

#content {

height:auto;

width: 740px;

line-height: 1.5em;

padding: 10px;

}

#content p {

text-indent: 2em;

}

#content h3 {

font-size: 16px;

margin: 10px;

}

#footer {

height: 50px;

width: 740px;

line-height: 2em;

text-align: center;

background-color: #009966;

padding: 10px;

}

-->

</style>

在这个CSS定义的盒子内加上内容

结构代码是这样的:

<body>

<div id="header"></div>

<ul id="nav">

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

<li><a href="#">文 章</a></li>

<li><a href="#">相册</a></li>

<li><a href="#">Blog</a></li>

<li><a href="#">论 坛</a></li>

<li><a href="#">帮助</a></li>

</ul>

<div id="content">

<h3>前言</h3>

<p>第一段内容</p>

<h3>理解CSS盒子模式</h3>

<p>第二段内容</p>

</div>

<div id="footer">

<p>关于华升 | 广告服务 | 华升招聘 | 客服中心 | Q Q留言 | 网站管理 | 会员登录 | 购物车</p>

<p>Copyright &copy;2006 - 2008 Tang Guohui. All Rights Reserved</p>

</div>

</body>

实例效果

 

【返回】