同类栏目:网站重构网页制作技巧Dreamweaver教程Fireworks教程Flash教程FrontPage教程Html教程css教程Javascript教程

CSS网页制作:z-index在IE中的迷惑

时间:2007-04-25 来源: 作者: 编辑:coyou

内容提要:CSS网页制作:z-index在IE中的迷惑z-index属性简介引用:z-index : auto | number auto: 默认值。number: 无单位的整数值,可为负数 。z-index值较大的元素将叠加在z-index值较小的元素之上。对于未指定此属性的定位对

CSS网页制作:z-index在IE中的迷惑

z-index属性简介

引用:

z-index : auto | number

auto: 默认值。

number: 无单位的整数值,可为负数 。

z-index值较大的元素将叠加在z-index值较小的元素之上。对于未指定此属性的定位对象,z-index 值为正数的对象会在其之上,而 z-index 值为负数的对象在其之下。

注意:这个属性不会作用于窗口控件,如 select 对象。

在IE5.5+中, iframe 对象开始支持此属性。而在之前的浏览器版本中, iframe 对象是窗口控件,会忽略此属性。

z-index属性适用于定位元素(position 属性值为 relative 或 absolute 或 fixed的对象),用来确定定位元素在垂直于显示屏方向(称为Z轴)上的层叠顺序(stack order)。

每一个定位元素都归属于一个stacking context。根元素形成root stacking context,而其他的stacking context则由定位元素产生(此定位元素的z-index被定义一个非auto的z-index值),定位子元素会以这个local stacking context为参考,用相同的规则来决定层叠顺序。并且stacking context和 containing block 之间并没有必然联系。

当stacking context一样的时候,就用z-index的值来决定怎样显示,如果z-index也相同(即stack level相同),则按照档中后来者居上的原则(back-to-front )的顺序来层叠。

当任何一个元素层叠另一个包含在不同stacking context元素时,则会以stacking context的层叠级别(stack level)来决定显示的先后情况。也就是说,在相同的stacking context下才会用z-index来决定先后,不同时则由stacking context的z-index来决定。例如:

定位元素A(z-index:100)里面有定位元素A1(z-index:300),而定位元素B和元素A兄弟关系(z-index:200)。你会发现无论A1的z-index是多大,也会被z-index是200的B所覆盖,因为A的z-index只有100。

阅读更详细的内容:http://www.w3.org/TR/CSS21/visuren.html#z-index

首先先来看一个演示例子的代码部分。

XHTML部分

<div id="container">

<div id="box1">这个box应该在上面</div>

</div>

<div id="box2">这个box应该在下面,IE浏览器会对定位元素产生一个新的stacking context ,甚至当元素 z-index的为“auto”。</div>

CSS部分

#container { position: relative; }

#box1 { position: absolute; top: 100px; left: 210px; width: 200px; height: 200px; background-color: yellow; z-index: 20; }

#box2 { position: absolute; top: 50px; left: 160px; width: 200px; height: 200px; background-color: green; z-index: 10; }

两个box被完全的定位,背景色为黄色的box1拥有z-index属性值20,而背景色为绿色的box2拥有z-index属性值10,唯一的区别在于背景色为黄色的box1被放在了一个定义了属性position:relative的div 中,并且在文档源代码中位前。

根据上述代码以及z-index的属性简介,我们来分析上面代码将会产生的效果位置。

CSS specification 中清楚的规定了除了根元素,只有定位元素的z-index被定义一个非auto的z-index值才能产生新的stacking context。而例子中被相对定位的元素并没有定义z-index,即z-index为默认值auto。所以按理他不会影响子元素的层叠顺序。即背景色为黄色的box1和背景色为绿色的box2的stacking context相同,即都为根元素产生的root stacking context。再根据规则中当stacking context一样的时候,就用z-index的值来决定怎样显示的原理,则应该z-index属性值20的背景色为黄色的box1在z-index属性值10背景色为绿色的box2之上。

下面我们在FF和IE中分别测试最终的效果,会发现FF中显示的效果和上面分析的效果是完全一致的,而IE中的显示却不一致

分页:[1] 2

上一篇:CSS技巧!像table一样布局div
下一篇:下面没有链接了

大学生博客: 免费、个性化域名、日志、相册、下载、好友…… 个性模板,大学生开博理想选择!

相关阅读:

·实例操作 如何让杀毒软件成“睁眼瞎”  (2007-04-25 19:01:59)
·十一种常见流氓软件完全卸载方法  (2007-04-25 18:57:00)
·asp网页提升速度方法5则  (2007-04-24 23:32:03)
·适合新手的闪字动画制作教程  (2007-04-24 23:07:38)
·Windows XP中快速进入网络连接窗口  (2007-04-24 22:04:07)
·多种方法帮你移除IE7搜索框  (2007-04-24 21:27:01)
·提高IE7同时下载的文件数  (2007-04-24 21:22:54)
· IE7Pro 0.9.14 发布  (2007-04-24 21:16:02)
·C#图像放大问题解决方法  (2007-04-24 00:21:47)
·Java程序最容易犯的21种错误实例分析  (2007-04-24 00:20:25)

用户名: (注册) 密码: 网友评论:

发表评论:
匿名 验证码:
·尊重网上道德,遵守《全国人大常委会关于维护互联网安全的决定》及中华人民共和国其他各项有关法律法;
·本站有权保留或删除您发表的任何评论内容;
·本站提醒:不要进行人身攻击与无聊谩骂。谢谢配合。
博客之星:

工具软件教程推荐阅读:


操作系统教程推荐阅读:

办公软件教程推荐阅读:

聊天软件教程推荐阅读:

网页制作教程推荐阅读:

平面设计教程推荐阅读:

设计欣赏推荐阅读:

程序开发教程推荐阅读:
网站简介 | 广告服务 | 联系方式 | 意见建议 | 网站地图 | 版权声明 | 友情连接
大学生网 Stuun.Com 版权所有 Copyright©2006 All rights reserved