考试首页 | 考试用书 | 培训课程 | 模拟考场 | 考试论坛  
  当前位置:设计制作 > CSS/HTML > 文章内容
  

5日精通CSS层叠样式表(第5日)

 [ 2016年10月8日 ] 【

5.1 第5日
在样式表最后一天的课程中,我们将学习样式表最精彩的部分:定位和叠放。
我们都知道,在网页上利用HTML定位文字和图象是一件“令人心痛”的事情。我们必须使用表格标签和隐式GIF图象,即使这样也不能保证定位的精确,因为浏览器和操作平台的不同会使显示的结果发生变化。
而CSS能使你看到希望的曙光。利用今天我们即将学到的CSS属性,你可以精确地设定要素的位置,还能将定位的要素叠放在彼此之上,还有...还有......你自己慢慢看吧!
以下是今天将学习的各种属性:
定位
左边
顶部
宽度
高度
可视性
z-index
注意:由于CSS定位开发得比其它CSS属性晚,所以IE3不支持CSS定位属性。定位属性只能用于4.0版的浏览器。
下面我们回答第4天留下的小问题。


5.2 绝对定位
定位(左边和顶部)
定位属性将是网虫们打开幸福之门的钥匙:
H4 { position: absolute; left: 100px; top: 43px }
这项CSS规则让浏览器将<H4>的起始位置精确地定在距离浏览器左边100象素,距离其顶部43象素的位置,请观看代码的执行效果。
注意这里唯一设置了的是左边和顶部,也就说,文字将从左到右,从上到下载入浏览窗口。
左边和顶部属性很直观,左边(left)设定要素距浏览器窗口左边的距离,顶部(top)设定距离浏览器窗口顶部的距离。
设定这些距离时,你可以使用所学过的各种度单位或比例值。使用比例值时,比例值的是相对于母体要素的尺寸。
你可以定位什么呢?任何东西!段落、单词、GIF和JPEG图象、QUICKTIME电影等等。范例。


5.3 相对定位
绝对定位使你能精确地定位要素在页面的独立位置,而不考虑页面其它要素的定位设置。相对定位指你所定位的要素的位置相对于在文件中所分配的位置。例:
I { position: relative; left: 40px; top: 10px }
请点击查看代码的执行效果
相对定位的关键在于定位了的要素的位置是相对于它通常应在的位置进行定位。如果你停止使用相对定位,则文字的显示位置将恢复正常。范例。
使用相对定位时要小心,否则容易将页面弄得非常乱。
除了相对定位和绝对定位,你还可以使用static(静止)参数值。它的使用方法同普通HTML中的定位方法,不能附加特殊的定位设置。
还不错吧?下面我们将学习如何控制定位了的要素。

5.4 控制定位了的要素
除了控制定位要素的左上角位置,你还可以控制要素的宽度和高度,及要素在页面的可视性。
宽度
定位了的要素在页面上显示时仍然会从左到右一直显示。利用宽度属性就可以设定字符向右流动的限制,即设定要素的宽度。
DIV { position: absolute; left:
200px; top: 40px; width: 150px }
浏览器接到这项规则时,它将文字按照规则规定的效果显示,还将段落的最大水平尺寸限制在150象素。见范例。
宽度属性只适用于绝对定位的要素。你可以使用我们学过的任何一种长度单位,或使用比例值设定宽度,比例值指相对于母体要素的比例。
IE 4中,这项属性还可用于图象。你可以通过宽度设置人为地拉宽或压缩图象。
高度
理论上讲,高度应该和宽度的设置类似,只不过是在垂直方向上:
DIV { position: absolute; left: 200px; top: 40px; height:
150px }
这里我用了“理论上讲”,因为常用的几种浏览器都不支持高度属性。(你最多只能在IE
4中用高度设置拉长图象。)
可视性
利用CSS,你可以隐藏要素,使其在页面上看不见。这条属性对于定位了的和未定位的要素都适用。
H4 { visibility: hidden }
我很想给你看一个例子,但是,因为要将它设为看不见,那我这个例子让你看什么呢?
选项:
visible使要素可以被看见
hidden使要素被隐藏
inherit指它将继承母体要素的可视性设置。
当一个要素被隐藏后,它仍然要占据浏览器窗口中的原有空间。所以,如果你将文字包围在一幅被隐藏的图象周围,那么,其显示效果将是文字包围着一块空白区域。
这条属性在编写语言和使用动态HTML时很有用,比如你可以使某段落或图象只在鼠标滑过时才显示。
Communicator不支持可视性属性。只有IE 4的用户可以享受其美妙之处!


5.5 叠放文字和图象
下面我将要谈到我一直吹嘘的在页面上重叠要素的方法。它不是通过设定边距负值或采用更小的行高来实现,而是通过......
z-index
当你定位多个要素并将其重叠时,你可以使用z-index来设定哪一个要素应出现在最上层。
H2 { position: relative; left: 10px; top: 0px; z-index: 10
}
H1 { position: relative; left: 33px; top: -35px; z-index: 1 }
观察这条CSS规则的执行效果(我将<H2>的文字设为绿色,以便你观察其不同之处):
Stylesheets
Mania
由于<H2>文字的z-index参数值更高,所以它显示在
<H1>文字的上面。(IE 4在MAC机上执行这一项时会出问题,它会将<H1>放在最上面。
该参数值使用纯整数。z-index用于绝对定位或相对定位了的要素。
你也可以给图象设定z-index。(对于Communicator,最好将
<IMG>标签包在<SPAN>或 <DIV>标签内,然后将z-index应用到<SPAN>或
<DIV>。)范例。


5.6 同低版本浏览器的兼容性
(SORRY! 内容暂无)


5.7 放眼未来
World Wide Web组织自规定了样式表标准之后并未止步不前。甚至在主要的几种浏览器尚未完全支持CSS功能时,CSS2已经在酝酿之中。CSS2的标准已经制定。而接下来的问题只是:5.0版本的浏览器是否会支持CSS2。
以下简要介绍CSS的新增功能:
对CSS1的调整
CSS属性中又加了几项,比如icon将意味着文字内容的尺寸应符合计算机正在使用的icon文字的尺寸。定义选择器(selector)和情景选择器(contextual
selector)的方法也将更加灵活。
新增的“绝技”
新的文字阴影属性将会受到大家的欢迎。
想使鼠标滑过某一链接时鼠标显示的手形有所改变吗?你可以使用光标属性设定鼠标显示的不同形状。
记得我们怎样用 A:active来设定用户点击链接文字时的属性吗?:hover将使我们能够实现当鼠标移到文字上面时就改变文字显示。很酷吧!
这些只是未来CSS的几种小把戏。
控制表格
我们设计网页布局时总是要用到表格,学习完本课程之后,我们还可以用CSS来设计网页布局。如果利用CSS能更好地控制表格,那该有多好。是的,它能够做到。
此外,你还能够控制文件打印时的分页,你还可以制定某些打印指令。
你还有可能实现通过声控系统进入你的网页。诸如voice-family和speech-rate等属性将设定如何将你的网页内容用声音自动朗读出来。


5.8 第5日的练习
熟能生巧。所以我们需要加强实践。
请观看本页,并重新制作出其效果。或者至少想出自己应该怎样实践才能实现这些效果。注意:为使范例能正确显示,你必须安装4.0版本的浏览器。
(我也充分认识到这个范例做得很傻,这只是一个例子。sorry!)


5.9 复习
祝贺你学完了本次课程!
今天我们学习了定位和叠放,总结如下:
定位(position)是最令人中意的CSS属性,你可以利用它精确地控制某要素在页面的位置。
左边(left)用于设定要素的水平位置。
顶部(top)用于设定要素的垂直位置。
宽度(width)使你能控制要素的显示宽度。
高度(height)用于设定要素的高度。
可视性(visibility)用于设定显示还是隐藏某要素。
z-index使你能设定重叠的要素中那个要素显示在最上面。
希望本次课程对你有所帮助。还有很多CSS的功能我们还没有涉及。还有一些小的浏览器问题我们也没有一一列出。所以你自己还必须继续深入学习。
互联网上的CSS资源
The Official Home of
CSS - World Wide Web组织有关CSS的新闻和动向,包括正式制定的 CSS1 和 CSS2
标准(CSS2目前还只是一个待批准的建议)
Webmonkey's
Stylesheets Collection - 网猴的CSS内容集锦。
Web Review Style
Sheets Reference Guide - CSS在不同浏览器上的适用规格最新指南。
CSSCheck
- 检查你的CSS代码的语法。
CSS Pointers -
有关CSS相当完整的资源链接清单。
comp.infosystems.www.authoring.stylesheets
- Usenet新闻组,共享和探讨CSS的问题及解决方案。
感谢你学完了本课程。你现在已经掌握了样式表的威力。你可以利用CSS在互联网尽情发挥自己的创意,体现你的才华!

本文纠错】【告诉好友】【打印此文】【返回顶部
将考试网添加到收藏夹 | 每次上网自动访问考试网 | 复制本页地址,传给QQ/MSN上的好友 | 申请链接 | 意见留言 TOP
关于本站  网站声明  广告服务  联系方式  站内导航  考试论坛
Copyright © 2007-2013 中华考试网(Examw.com) All Rights Reserved