[实例]十步学会用div css建站_第1页
[实例]十步学会用div css建站_第2页
[实例]十步学会用div css建站_第3页
[实例]十步学会用div css建站_第4页
[实例]十步学会用div css建站_第5页
已阅读5页,还剩49页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第一步:规划网站,本教程将以图示为例构建网站;第二步:创建html模板及文件目录等;第三步:将网站分为五个div,网页基本布局的基础;第四步:网页布局与div浮动等;第五步:网页主要框架之外的附加结构的布局与表现;第六步:页面内的基本文本的样式(css)设置;第七步:网站头部图标与logo部分的设计;第八步:页脚信息(版权等)的表现设置;第九步:导航条的制作(较难);第十步:解决IE浏览器的显示BUG;第一步:规划网站,本教程将以图示为例构建网站第一步:规划网站,本教程将以图示为例构建网站 1.规划网站,本教程将以下图为例构建网站。规划网站,本教程将以下图为例构建网站。 其基本布局见下图其基本

2、布局见下图 规划网主要由五个部分构成规划网主要由五个部分构成 1.Main Navigation 导航条,具有按钮特效。导航条,具有按钮特效。 Width: 760px Height: 50px 2.Header 网站头部图标,包含网站的网站头部图标,包含网站的logo和站名。和站名。 Width: 760px Height: 150px 3.Content 网站的主要内容。网站的主要内容。 Width: 480px Height: Changes depending on content 4.Sidebar 边框,一些附加信息。边框,一些附加信息。 Width: 280px Height:

3、Changes depending on content5.Footer 网站底栏,包含版权信息等。网站底栏,包含版权信息等。 Width: 760px Height: 66px。 第二步:创建第二步:创建htmlhtml模板及文件目录等模板及文件目录等 1.创建创建html模板模板 代码如下代码如下 CompanyName - PageName import css/master.css;将其保存为index.html,并创建文件夹css,images,网站结构如下2.2.创建网站的大框,即建立一个宽760px的盒子,它将包含网站的所有元素。 在html文件的和之间写入Hello world

4、.创建css文件,命名为master.css,保存在/css/文件夹下。写入:#page-container width: 760px;background: red;控制html的id为page-container的盒子的宽为760px,背景为红色。表现如下 现在为了让盒子居中,写入margin: auto;,使css文件为:#page-container width: 760px;margin: auto;background: red;现在你可以看到盒子和浏览器的顶端有8px宽的空隙。这是由于浏览器的默认的填充和边界造成的。消除这个空隙,就需要在css文件中写入:html, body m

5、argin: 0;padding: 0;第三步:将网站分为五个第三步:将网站分为五个divdiv,网页基本布局的基础,网页基本布局的基础 1.1.将将“第一步第一步”提到的五个部分都放入盒子中,在提到的五个部分都放入盒子中,在htmlhtml文件中写入:文件中写入: Main Nav Header Sidebar A Content Footer 表现如下:表现如下: 2.为了将五个部分区分开来,我们将这五个部分用不同的背景颜色标示出来,在css文件写入 #main-nav background: red;height: 50px;#header background: blue;height

6、: 150px;#sidebar-a background: darkgreen;#content background: green;#footer background: orange;height: 66px; 表现如下 第四步:网页布局与第四步:网页布局与divdiv浮动等浮动等 1.浮动,首先让边框浮动到主要内容的右边。用css控制浮动#sidebar-a float: right;width: 280px;background: darkgreen;表现如下 2.往主要内容的盒子中写入一些文字。在html文件中写入 Lorem ipsum dolor sit amet, conse

7、ctetuer adipiscing elit. Nullam gravida enim ut risus. Praesent sapien purus, ultrices a, varius ac, suscipit ut, enim. Maecenas in lectus.Donec in sapien in nibh rutrum gravida. Sed ut mauris. Fusce malesuada enim vitae lacus euismod vulputate. Nullam rhoncus mauris ac metus. Maecenas vulputate ali

8、quam odio. Duis scelerisque justo a pede. Nam augue lorem, semper at, porta eget, placerat eget, purus. Suspendisse mattis nunc vestibulum ligula. In hac habitasse platea dictumst. 表现如下 但是你可以看到主要内容的盒子占据了整个page-container的宽度,我们需要将#content的右边界设为280px。以使其不和边框发生冲突。 css代码如下:#content margin-right: 280px;ba

9、ckground: green;同时往边框里写入一些文字。在html文件中写入:Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Nullam gravida enim ut risus. Praesent sapien purus, ultrices a, varius ac, suscipit ut, enim. Maecenas in lectus. Donec in sapien in nibh rutrum gravida. Sed ut mauris. Fusce malesuada enim vitae lacus

10、 euismod vulputate. Nullam rhoncus mauris ac metus. Maecenas vulputate aliquam odio. Duis scelerisque justo a pede. Nam augue lorem, semper at, porta eget, placerat eget, purus. Suspendisse mattis nunc vestibulum ligula. In hac habitasse platea dictumst.表现如下 这也不是我们想要的,网站的底框跑到边框的下边去了。这是由于我们将边框向右浮动,由于

11、是浮动,所以可以理解为它位于整个盒子之上的另一层。因此,底框和内容盒子对齐了。因此我们往css中写入: #footer clear: both;background: orange;height: 66px; 表现如下 第五步:网页主要框架之外的附加结构的布局与表现第五步:网页主要框架之外的附加结构的布局与表现 第五步主要介绍除网页主要框架之外的附加结构的表现(Layout),包括以下内容: 1.主导航条;2.标题(heading),包括网站名和内容标题;3.内容;4.页脚信息,包括版权,认证,副导航条(可选)。 加入这些结构时,为了不破坏原有框架,我们需要在css文件body标签(TAG)下

12、加入:.hidden display: none;.hidden即我们加入的类(class),这个类可以使页面上任意属于hidden类的元素(element)不显示。这些会在稍后使用,现在请暂时忘记它。现在我们加入标题(heading) 先回到先回到HTMLHTML的代码,的代码,到到是我们常用的是我们常用的htmlhtml标题代码。比如我标题代码。比如我们一般用们一般用网站名网站名,网站副标题网站副标题,内容主标题内容主标题等。我们往等。我们往htmlhtml文件文件 的的HeaderHeader层层(Div)(Div)加入加入: : Enlighten Designs 刷新一下页面,你就可

13、以看到巨大的标题,和标题周围的空白,这是刷新一下页面,你就可以看到巨大的标题,和标题周围的空白,这是因为因为标签的默认大小和边距标签的默认大小和边距(margin)(margin)造成的,先要造成的,先要消除这些空白消除这些空白, ,需需要加入:要加入: h1 margin: 0;padding: 0; 接下来是导航条 控制导航条表现的控制导航条表现的csscss代码相对比较复杂,我们将在第九步或是代码相对比较复杂,我们将在第九步或是第十步中详细介绍。现在第十步中详细介绍。现在htmlhtml文件加入导航代码文件加入导航代码: : AboutServicesPortfolioContact U

14、s 目前导航条的表现比较糟糕,但是要在以后的教程中介绍其特殊表现,故需要暂时隐藏导航条,于是加入: AboutServicesPortfolioContact Us 我们跳一步,先到页脚: 页脚包括两部分:左边的版权页脚包括两部分:左边的版权, ,认证和右边的副导航条。认证和右边的副导航条。我们先要让副导航条向右浮动,就像之前处理我们先要让副导航条向右浮动,就像之前处理SidebarSidebar和和ContentContent关系的关系的一样,需要加入一个新的层一样,需要加入一个新的层(div): (div): About - Services - Portfolio - Contact U

15、s - Terms of Trade 理论上,我们可以控制源文件上的任意元素的浮动,但由于理论上,我们可以控制源文件上的任意元素的浮动,但由于IEIE浏览浏览器的器的BUGBUG,被浮动层需要首先出现在源文件上,也就是说我们把副标题,被浮动层需要首先出现在源文件上,也就是说我们把副标题放在版权和认证的前面:放在版权和认证的前面: About - Services - Portfolio - Contact Us - Terms of TradeCopyright © Enlighten DesignsPowered by Enlighten Hosting andVadmin

16、 3.0 CMS 刷新你的页面,你将看到如下所示 最后我们回到内容部分:最后我们回到内容部分:用h2表现内容标题About,Contact us;用表现段落;用断行。 AboutEnlighten Designs is an Internet solutions provider that specialises in front and back end development. To view some of the web sites we have created view our portfolio.We are currently undergoing a face lift, s

17、o if you have any questions or would like more information about the services we provide please feel free to contact us.Contact UsPhone: (07) 853 6060Fax: (07) 853 6060Email: infoenlighten.co.nzP.O Box: 14159, Hamilton, New ZealandMore contact information 刷新页面可以看到在刷新页面可以看到在ContentContent层中又出现一些空白,这是

18、由于层中又出现一些空白,这是由于标签的默认边距标签的默认边距(margin)(margin)造成的,我们必须造成的,我们必须 消除这些恼人的空白,当又不消除这些恼人的空白,当又不想把网页中所有的想把网页中所有的标签地边距都设为标签地边距都设为0 0,这就需要使用,这就需要使用csscss的子选择的子选择器器(child css selector),(child css selector),在在htmlhtml的文件结构中,我们想控制的的文件结构中,我们想控制的标签标签( (childchild) )是属于是属于#content#content层层( (parentparent) )的的, ,因

19、此在因此在csscss文件中写入:文件中写入: #content h2 margin: 0;padding: 0;#content p margin: 0;padding: 0; 这样我们就告诉浏览器,这样我们就告诉浏览器,仅仅是隶属于仅仅是隶属于contentcontent层的层的标签的标签的marginmargin和和paddingpadding的值为的值为0 0! 第六步:页面内的基本文本的样式第六步:页面内的基本文本的样式(css)(css)设置设置 你是不是厌倦了那些大红大绿的背景,现在是去掉它们的时候了,你是不是厌倦了那些大红大绿的背景,现在是去掉它们的时候了,只保留导航条的红色背

20、景。很好,再过几步,你就能很好了解只保留导航条的红色背景。很好,再过几步,你就能很好了解csscss控制整个控制整个网页版面网页版面(Layout)(Layout)的能力。的能力。 先设置全局的文本样式:先设置全局的文本样式: body font-family: Arial, Helvetica, Verdana, Sans-serif;font-size: 12px;color: #666666;background: #ffffff; 一般我们把一般我们把bodybody标签放在标签放在csscss文件的顶端,当然你要是执意要把它放在文件的顶端,当然你要是执意要把它放在尾部,浏览器不会和你

21、计较。尾部,浏览器不会和你计较。font-familyfont-family内的顺序决定字体显示优先级,内的顺序决定字体显示优先级, 比方如果所在计算机没有比方如果所在计算机没有ArialArial字体,浏览器就会指向字体,浏览器就会指向HelveticaHelvetica字体,依字体,依次类推;次类推;colorcolor指字体颜色;指字体颜色;backgroundbackground指背景颜色。指背景颜色。 如果你都是按本教程的操作,应该能看到下图 你可以看到内容(content)的各块(block)之间的间隙太小了,而基于最初的设计,内容标题(即)和正文之间的间隙大概是15px,每个段落

22、的间距也大概是15px,所以在css中写入: #content h2 margin: 0;padding: 0;padding-bottom: 15px;#content p margin: 0;padding: 0;padding-bottom: 15px; 然后需要让content层的四周都空出25px的间隙,这本来是件很简单的事,理论上我们只需在#content的css文件中加入padding: 25px;就行了,但是IE给我们上了“一课”,它的固有BUG根本不能按我们的想象表现。解决这个问题有两种办法。第一种办法是区别浏览器写入两种代码(HACK IE),但因为间隙(padding,在

23、Dreamweaver中又叫填充)使用很频繁,所以我们用另一种办法。 我们往需要填充的层中加入padding层,它的功能仅限于显示间隙: Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Nullam gravida enim ut risus. Praesent sapien purus, ultrices a, varius ac, suscipit ut, enim. Maecenas in lectus. Donec in sapien in nibh rutrum gravida. Sed ut mauris. Fus

24、ce malesuada enim vitae lacus euismod vulputate. Nullam rhoncus mauris ac metus. Maecenas vulputate aliquam odio. Duis scelerisque justo a pede. Nam augue lorem, semper at, porta eget, placerat eget, purus. Suspendisse mattis nunc vestibulum ligula. In hac habitasse platea dictumst. 同样的,再往html文件的con

25、tent层中加入padding层。由于padding层的功能仅是制造空隙,所以不要设置它的宽度,只需在css中添加: #sidebar-a float: right;width: 280px;#sidebar-a .padding padding: 25px;#content margin-right: 280px;#content .padding padding: 25px; 就像我们之前用的方法一样,我们只选择了类就像我们之前用的方法一样,我们只选择了类(class)(class)为为paddingpadding,且,且父类父类(parent)(parent)为为#content#con

26、tent或或#sidebar-a#sidebar-a的元素的元素(element)(element)。 接下来设置行距,接下来设置行距,contentcontent和和sidebar-asidebar-a的行距需要加宽,但在的行距需要加宽,但在csscss中是中是没有行距没有行距(leading)(leading)这种属性这种属性(attribute)(attribute)的,但是有的,但是有行高行高(line-height)(line-height)属属性,因此往性,因此往csscss中写入:中写入: #sidebar-a float: right;width: 280px;line-hei

27、ght: 18px;#content margin-right: 280px;line-height: 18px; 现在可以看到标题现在可以看到标题aboutabout和和contact uscontact us显得相当突兀,这是显得相当突兀,这是因为我们使用的字体并不是一种网页字体,我们需要将其替换为图片,因为我们使用的字体并不是一种网页字体,我们需要将其替换为图片,并将其存放于并将其存放于/images/headings/images/headings/文件夹中:文件夹中: 替换方法为,在html文件的标签中写入: 于是得到下图 第七步:网站头部图标与第七步:网站头部图标与logologo

28、部分的设计部分的设计 为实现设计时的网页头部效果,我们需要以下两幅图:/images/headers/about.jpg /images/general/logo_enlighten.gif 首先我们给首先我们给#header#header层添加背景图案层添加背景图案 #header height: 150px;background: #db6d16url(./images/headers/about.jpg); 我们使用的背景属性为一些简写的属性名,用其能规定背景的颜色,图案,图案的位置,是否重复以及如何重复。之所以把背景色设为桔黄色,是因为当用户使浏览 器屏蔽图片时,网站的头部不会变的一片

29、空白。应该注意到图片的路径是相对于css的存放位置而言的,而不是html文件,因此有./。 接着替换掉接着替换掉标签里的标签里的Enlighten Designs Enlighten Designs logo_enlightenlogo_enlighten图片浮在头部的左上方,我们需要设置图片浮在头部的左上方,我们需要设置的属性值为的属性值为 h1 margin: 0;padding: 0;float: right;margin-top: 57px;padding-right: 31px; 这样我们使存在于这样我们使存在于层的图片向右浮动,并且上边距层的图片向右浮动,并且上边距(margin-

30、top)(margin-top)为为57px57px,右间隙,右间隙(padding-right)(padding-right)为为31px31px,如下图所示,如下图所示 注意:细心的你可能会发现我们使用了注意:细心的你可能会发现我们使用了padding-right而不是而不是margin-right,这是因为,这是因为IE的怪毛病不少,它会在不定的地方无法正确显的怪毛病不少,它会在不定的地方无法正确显 示示margin-right/left属性,所以使用了属性,所以使用了padding(间隙间隙,Dreamweaver中又中又被称为填充被称为填充)属性。属性。 希望大家在以后的希望大家在以

31、后的css编写过程中,尽量使用编写过程中,尽量使用padding属性,以免造成属性,以免造成浏览器调试麻烦。浏览器调试麻烦。 第八步:页脚信息第八步:页脚信息( (版权等版权等) )的表现设置的表现设置 首先需要控制页脚的文本显示: #footer clear: both;height: 66px;font-family: Tahoma, Arial, Helvetica, Sans-serif;font-size: 10px;color: #c9c9c9; 接着我们需要设置存在链接的文本的显示,在这我们没有改变文本的颜色(仍然为#c9c9c9),而只是让下划线消失:#footer a col

32、or: #c9c9c9;text-decoration: none; 但是我们想让那些存在链接的文本,在鼠标悬停在其上方时变色为#db6d16: #footer a:hover color: #db6d16; 然后我们想给页脚加上灰色的上边框,在footer层的四周设置一些间隙,并加大文本的行距: #footer clear: both;height: 66px;font-family: Tahoma, Arial, Helvetica, Sans-serif;font-size: 10px;color: #c9c9c9;border-top: 1px solid #efefef;paddin

33、g: 13px 25px;line-height: 18px; 最后我们需要做的就是让副导航层(#altnav)向右浮动,需要指出的是,浮动层是必须设置宽度(width)才能正常浮动的,所以我们把#altnav的宽度设置为350px,略宽于文本的长度(为了让副标题的文字显示完全),然后让文本向右对齐: #footer #altnav width: 350px;float: right;text-align: right; 如果你按照以上方法,将得到如下图所示的页脚样式如果你按照以上方法,将得到如下图所示的页脚样式 第九步:导航条的制作第九步:导航条的制作( (较难较难) ) 注注: :导航条之

34、所以放在第九步讲,是因为导航条制作是本教程中最难的导航条之所以放在第九步讲,是因为导航条制作是本教程中最难的部分,自然也是技术含量最高的地方部分,自然也是技术含量最高的地方. .导航条的制作可易可难,但这里介绍导航条的制作可易可难,但这里介绍的相对较难,您能坚持到这一步已经很不易,如果你只是有个导航条就满足的相对较难,您能坚持到这一步已经很不易,如果你只是有个导航条就满足的话,请参考第八步的制作。的话,请参考第八步的制作。 先去掉导航条的红色背景,还有就是移除html文件中main-nav层的class=hidden,使导航条的内容显示出来。我们实现导航条图 片的变换的方法是纯css代码的,不

35、包含任何js或是flash,因此我们所用的图片是4幅分别由三个小图组合而成的图片,如下所示,并将这4幅图保存于 /images/nav/文件夹中 我们实现导航条的动态效果如下图所示我们实现导航条的动态效果如下图所示 在网页显示的只是图中红框标出的部分,如果把每幅图分为上,中,下三部分的话,未发生动作时显示上部,当光标悬停时,显示的是中部,被选择时则显示下部。 接下来进入接下来进入csscss代码部分,先往代码部分,先往csscss文件中写入文件中写入 /* Main Navigation */#main-nav height: 50px; #main-nav ul margin: 0; pad

36、ding: 0; 注意:注意:/ /* * Main Navigation Main Navigation * */ /为增加为增加csscss文件可读性的说明,不会影响表现。文件可读性的说明,不会影响表现。#main-nav#main-nav的的heightheight属性定义了属性定义了main-navmain-nav层的高度;层的高度;#main-nav ul #main-nav ul 则定义则定义main-main-navnav层中列表的属性,在这里先定义其层中列表的属性,在这里先定义其marginmargin和和paddingpadding为为0 0。 根据先前的设计,导航条应该和左

37、边有一定的距离,这就需要设置根据先前的设计,导航条应该和左边有一定的距离,这就需要设置main-main-navnav层的左边距层的左边距(padding-left)(padding-left)为为11px,11px,但由于但由于IE5IE5和和MacMac浏览器的浏览器的BUGBUG,需要加,需要加入以下代码:入以下代码: /* IE5 Mac Hack */ #main-nav padding-left: 11px; /*/ #main-nav padding-left: 11px; overflow: hidden; /* End Hack */ 现在你可以看到导航列表距左边有11px的

38、距离,但是列表项目是竖排的,将,即列表项目向左对齐就能使其从左到右横向排列 #main-nav li float: left; 为了使列表项目的尺寸和容纳它的层保持一致,并利用浮动属性使列表项目的文本隐藏,写入: #main-nav li a display: block;height: 0px !important;height /*/:50px; /* IE 5/Win hack */ padding: 50px 0 0 0;overflow: hidden;background-repeat: no-repeat; 接着,要实现当光标悬停于列表项目上时,显示背景图片的中部,因此需要将背景

39、图片向上移动50px,写入: #main-nav li a:hover background-position: 0 -50px; 给各个列表项目设置宽度和背景图片的路径: #main-nav li#about,#main-nav li#about a width: 71px; background-image: url(./images/nav/about.gif); #main-nav li#services,#main-nav li#services a width: 84px; background-image: url(./images/nav/services.gif); #mai

40、n-nav li#portfolio,#main-nav li#portfolio a width: 95px; background-image: url(./images/nav/portfolio.gif); #main-nav li#contact,#main-nav li#contact a width: 106px; background-image: url(./images/nav/contact.gif); 最后我们要做的就是,当列表项目被选时,显示背景图片的下部。为此我们需要增加一些css代码对原有的css表现作一些修改: body.about li#about,body.

41、about li#about a,body.services li#services,body.services li#services a,body.portfolio li#portfolio,body.portfolio li#portfolio a,body.contact li#contact,body.contact li#contact a background-position: 0 -100px; 以上看似庞大的以上看似庞大的csscss选择器可以识别选择器可以识别bodybody标签的类标签的类(class)(class),如,如htmlhtml中为:中为: 以上以上css

42、css选择器就让选择器就让li#about,li#about a,li#about,li#about a,的背景向上移动的背景向上移动100px100px,使,使其显示背景图片的下部。其显示背景图片的下部。 如果我们希望网站头部背景图片也根据如果我们希望网站头部背景图片也根据bodybody标签的类进行变换,就需修标签的类进行变换,就需修改改csscss的的#header#header为:为:body.about #header height: 150px;background: #db6d16url(./images/headers/about.jpg); 至此就完成了About网页的制作,依此类推,修改html中body的类为services/portfolio/contact制作相应html文件并分别保存。在css文件中添加各个网页相

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论