css z-index 在IE中的迷惑


z-index属性简介

引用:
z-index : auto | number

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

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

注意:这个属性不会作用于窗口控件,如selct 对象。在IE 5.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。

IE中z-index BUG
首先先来看一个演示例子的代码部分。
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之上。



相关阅读:
解决Vista复制文件速度缓慢
Jquery操作radio,checkbox,select表单操作实现代码
静态图片的十一种滤镜效果--不支持Ie7及非IE浏览器。
纯语义化XHTML+CSS设计表单方法
計算你開發的 PHP 程式大小
sql2005 数据同步方法
使用TextRange获取输入框中光标的位
jquery绑定原理 简单解析与实现代码分享
firebug的一个有趣现象介绍
Oracle10gR2上遇到了Mutex竞争的问题
汇总整理MYSQL相关操作命令
FreeBSD 6.2-RELEASE下用freebsd-update升级过程
javascript表单之间的数据传递
什么是DOM(Document Object Model)文档对象模型
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 小学五年级作文800字:爷爷和自行车 蛇王淘金(上) 激烈的接力赛350字 故乡的七夕 六年级作文500字:一个令我难忘的人 秋千作文1000字 感恩母亲节作文580字 蜷曲,于岁月静好 转正申请书范文:预备党员 一个人慢慢走 2015年英语演讲主题 书籍我的老师作文 ~~不是错过才知道珍惜,那不配~~ 命运开了个玩笑,而我不能翻脸_励志人物 小学三年级作文600字:小猫学本领 2012年春季少先队工作总结 欠二月文字,三月补上 散文随笔:莫让心灵蒙尘 光阴里修行 高考语文古诗词常见意象总结 每日一乐 4 关于政治教学年度工作总结 2017七夕祝福 动物王国的大会作文300字 小狗贝贝作文700字 风在耳边的停留 市政府的财政财务工作报告【范文参考】 感动日记 散文:战之殇 描写月光的优美诗句 致可爱的留学生们 2012年中学学校工会工作总结 水果皇后——山竹作文 2015入党誓词内容 寂桐词佐波子 让青春舞动起来吧作文500字 小学四年级作文350字:4 罗密欧与朱丽叶好词好句 展望作文600字 2005年厦门市中考满分作文:那一次,我读懂了他们作文900字 汽车配件分公司开业庆典主持词 幸福过 伤害了 那就离开吧 落雨作文1800字 我是帅气的音乐老师 烛影摇红(上元有怀) 交通事故警示片观后感 带图片的空间说说 公司2015年度总结表彰大会讲话稿 开展学党章守纪律当先锋主题教育活动情况报告 藍格调

Copyright © 2016 phpStudy |