关于z-index网上其实有不少博文,写得也不错,不过有些帖子比较旧,而IE也已经更新到了IE11了,所以还是重新总结一下。由于 z-index 的属性表现和层级有关,有些特点在某些层级下才表现出来,所以按层次来举例子梳理比较清楚。

单层节点情况 z-index 的基本特点:
1、当不设置 position 或者设置 position 的值为 static 时,文档按照普通流顺序,后面的元素会覆盖前面的元素。内容方面则有区别,在chrome,opera,Firefox,IE8+中并不会覆盖内容部分(不过暂时对这个现象的本质不是很理解),而IE6,IE7则全部覆盖;
 
--------------------------------------------------------------举个栗子--------------------------------------------------------------
HTML:
 <div class="container">
<div class="div_1">
<p>未设置position的div_1</p>
</div>
<div class="div_2">
<p>div_2同样未设置position</p>
</div>
</div>
CSS:
 .div_1,.div_2{
width: 100px;
height:100px;
}
.div_1{
background:#ffff00;
border:10px solid #ffff00;
color:#0000ff;
}
.div_2{
background:#00ff00;
border:10px solid #00ff00;
margin-top: -70px;
color:#000;
}
chrome,opera,Firefox,IE8+表现如下:
而IE6,IE7表现如下:
--------------------------------------------------------------吃完栗子--------------------------------------------------------------
 

2、只有 position 的值为 absolute,relative,fixed 的时候 z-index 才有效,设置了有效 z-index 值的元素会创建一个层叠上下文(Stacking Contexts);

3、当设置 position 的值为 absolute,relative,fixed 而不显式设置 z-index 的值时,此时position设置为 absolute,relative,fixed 的元素会覆盖其他没有声明 position 或声明 position 为 static 的元素;
 
--------------------------------------------------------------举个栗子--------------------------------------------------------------
沿用上例,设置div_1的position属性为relative:
HTML:
 <div class="container">
<div class="div_1">
<p>设置position为relative的div_1</p>
</div>
<div class="div_2">
<p>div_2依然未设置position</p>
</div>
</div>
CSS:
 .div_1{
background:#ffff00;
border:10px solid #ffff00;
color:#0000ff;
position:relative;
}
chrome,Firefox,opera,IE6+均表现如下:
--------------------------------------------------------------吃完栗子--------------------------------------------------------------
 
4、当 position 为absolute,relative,fixed 的时候按 z-index 的值分层,z-index 的值可以为负值;
 
--------------------------------------------------------------举个栗子--------------------------------------------------------------
这里只举z-index的值可以为负数的例子,和上例一样,只是在设置 div_1 的 z-index 值为-1:
HTML:
 <div class="div_1">
<p>设置position为relative的div_1</p>
</div>
<div class="div_2">
<p>div_2依然未设置position为relative</p>
</div>

CSS:

 .div_1,.div_2{
width: 100px;
height:100px;
font-family: arial;
}
.div_1{
background:#ffff00;
border:10px solid #ffff00;
color:#0000ff;
position:relative;
z-index: -1;
}
.div_2{
background:#00ff00;
border:10px solid #00ff00;
margin-top: -70px;
color:#000;
}
chrome,Firefox,opera,IE6+均表现如下:
可见设置 z-index 为负数甚至比未设置 position 的div层次还要低。
 
(2015.4.30)补充:在 IE6,IE7 中会出现 bug,主要是 hasLayout 属性引起的。即当父元素设置 position:relative,div_1 触发了hasLayout 而 div_1 没有触发 hasLayout 时,设置 div_1 的 z-index 为-1时,仍然会覆盖 div_2 的 background,见例子:
HTML:
 <div class="wrap">
<div class="div_1">
<p>设置position为relative的div_1</p>
</div>
<div class="div_2">
<p>div_2依然未设置position为relative</p>
</div>
</div>

CSS:

 .wrap {
position: relative;
}
.div_1 {
background: #ffff00;
border: 10px solid #ffff00;
color: #0000ff;
position: absolute;
z-index: -1;
}
.div_2 {
background: #00ff00;
border: 10px solid #00ff00;
margin-top: 0px;
color: #000;
}

chrome,Firefox,opera,IE8+表现如下:

IE6,IE7表现如下:

解决方法:
1、去掉父元素的 position:relative 属性,这要看具体情况,当父元素自己定位需要或者需要为设置 position 为 absolute 的子元素提供定位基准的时候当然就不能轻易去掉了;
2、为 div_2 触发 hasLayout 属性,即修改 div_2 的 CSS为:
 .div_2 {
background: #00ff00;
border: 10px solid #00ff00;
margin-top: 0px;
color: #000;
*zoom:;/*触发div_2的hasLayout属性*/
}
--------------------------------------------------------------吃完栗子--------------------------------------------------------------
 
 
双层节点结构 z-index 的基本特点:
1、当设置 position 的值为 absolute,relative,fixed 而不显式设置 z-index 的值时,在chrome,Firefox,opera,IE8+上 z-index 的默认值为 auto,而IE6、IE7 的 z-index 的默认值为0;
2、若父级元素创建了层叠上下文(Stacking Contexts),子级元素层次永远比父级元素要高,即永远在父级元素上面;由双层节点结构基本特点1可知IE6、IE7中只要设置 position 的值为 absolute,relative,fixed 则会为元素创建一个层叠上下文(Stacking Contexts),所以这里会出现一些兼容性问题,下面会穿插讲述。
3、父级元素没有设置 position 或当父级元素设置了 position 但没有设置 z-index时,子级元素的比较和单层结构表现一样,当子级元素设置了有效的负的 z-index 值时,层级比父级元素低;
 
--------------------------------------------------------------举个栗子--------------------------------------------------------------
HTML:
 <div class="wrap_1">
<div class="div_1">
<p>设置position为relative,z-index为-1的div_1</p>
</div>
</div>

CSS:

 .wrap_1{
width: 200px;
background-color: #999;
}
.div_1{
width: 100px;
height:100px;
font-family: arial;
background:#ffff00;
border:10px solid #ffff00;
color:#0000ff;
position: relative;
z-index: -1;
}

chrome,Firefox,opera,IE6+表现如下:

chrome审查元素后可以看到 div_1 已经隐藏到 wrap_1 后面去了:

此时设置 wrap_1 的 position 属性为 relative:

 .wrap_1{
position: relative;
width: 200px;
background-color: #999;
}

此时chrome,Firefox,opera,IE8+表现不变,而IE6,IE7的表现为:

双层节点结构基本特点1可知,因为此时 wrap_1被默认设置 z-index 为0,子级元素 div_1 表现出双层节点结构基本特点2。显式设置 wrap_1 的 z_index 为0会在chrome,Firefox,opera,IE8+下有同样的显示效果;

--------------------------------------------------------------吃完栗子--------------------------------------------------------------
 
4、当父级元素设置了 position 且设置了 z-index 时,会创建一个层叠上下文(Stacking Contexts),子级元素的层级比较由父级元素决定,父级元素层级高,则子级元素层级就高。当父级元素的 z-index 的值相同时,则按照文档普通流先后顺序决定,即后面的元素层级更高;
 
--------------------------------------------------------------举个栗子--------------------------------------------------------------
HTML:
 <div class="wrap_1">
<div class="div_1">
<p>设置position为relative,z-index为10的div_1</p>
</div>
</div>
<div class="wrap_2">
<div class="div_2">
<p>div_2设置position为relative,z-index为100</p>
</div>
</div>

CSS:

 .wrap_1{
position: relative;
z-index:;
}
.wrap_2{
position: relative;
z-index:;
}
.div_1,.div_2{
width: 100px;
height:100px;
font-family: arial;
}
.div_1{
background:#ffff00;
border:10px solid #ffff00;
color:#0000ff;
position: relative;
z-index:;
}
.div_2{
background:#00ff00;
border:10px solid #00ff00;
margin-top: -70px;
color:#000;
position: relative;
z-index:;
}


chrome,Firefox,opera,IE6+均表现如下,因为父级元素设置了 z-index,且 wrap_1 的 z-index 的值大于 wrap_2 的 z-index 的值,子级元素表现跟随父元素:
--------------------------------------------------------------吃完栗子--------------------------------------------------------------
 
当父级元素设置 position 的值为 absolute,relative,fixed 而不显式设置 z-index 的值时,在chrome,Firefox,opera,IE8+ 表现出双层节点结构基本特点3,而IE6、IE7的浏览器则表现出双层节点结构基本特点4,即相当于设置了相同的 z-index 值;
 
--------------------------------------------------------------举个栗子--------------------------------------------------------------
HTML:
 <div class="wrap_1">
<div class="div_1">
<p>设置position为relative,z-index为2的div_1</p>
</div>
</div>
<div class="wrap_2">
<div class="div_2">
<p>div_2设置position为relative,z-index为1</p>
</div>
</div>
CSS:
 .wrap_1{
position: relative;
}
.wrap_2{
position: relative;
}
.div_1,.div_2{
width: 100px;
height:100px;
font-family: arial;
}
.div_1{
background:#ffff00;
border:10px solid #ffff00;
color:#0000ff;
position: relative;
z-index:;
}
.div_2{
background:#00ff00;
border:10px solid #00ff00;
margin-top: -70px;
color:#000;
position: relative;
z-index:;
}
chrome,Firefox,opera,IE8+表现如下:
IE6,IE7表现如下,因为 wrap_1 和 wrap_2 默认 z-index 的值为 0,值相同,则按照文档普通流顺序排列,后面的元素覆盖前面的元素,即 wrap_2 层级高于 wrap_1,他们的子元素表现均跟随父元素:
 
针对特点3和特点4,这里举一个例子可以看到两个特点的表现:
HTML:
 <div class="wrap_1">
<div class="div_1">
<p>设置position为relative,z-index为100的div_1</p>
</div>
</div>
<div class="wrap_2">
<div class="div_2">
<p>div_2设置position为relative,z-index为10</p>
</div>
</div>
CSS:
 .wrap_1{
position: relative;
z-index:;
}
.wrap_2{
position: relative;
}
.div_1,.div_2{
width: 100px;
height:100px;
font-family: arial;
}
.div_1{
background:#ffff00;
border:10px solid #ffff00;
color:#0000ff;
position: relative;
z-index:;
}
.div_2{
background:#00ff00;
border:10px solid #00ff00;
margin-top: -70px;
color:#000;
position: relative;
z-index:;
}
chrome,Firefox,opera,IE8+的表现如下。根据特点2,因为此时 div_1 父元素 wrap_1 设置了有效的 z-index 值,而 div_2 的父元素没有设置 z-index,故比较层级时,用 div_1 的父元素 wrap_1 的 z-index 值 2 和 div_2 的 z-index 值 10 比较,所以尽管 div_1 设置 z-index 的值为 100,还是跟随父元素层级小于 div_2:
IE6,IE7表现如下。根据特点3, wrap_2 有默认值 0,所以 div_1 和 div_2 的层级比较就变成了 wrap_1 和 wrap_2 的层级比较:
--------------------------------------------------------------吃完栗子--------------------------------------------------------------
 
多层和双层是一样的道理,兄弟元素直接比较 z-index 的值;否则用设置了有效 z-index 值(拥有层叠上下文)的祖先元素的 z-index 值进行比较。
 
注:
1、这里文章举的例子不是很多,因为里面很多基础的概念想必很多人都知道。更多例子可以参考 NeoEase 的 position 属性和 z-index 属性对页面节点层级影响的例子
2、这里讲到的 z-index 的特点是偏实用性的,很多基本概念并没有涉及。如果要比较深入地了解层叠上下文(Stacking Contexts)和 z-index 的原理和概念,需要阅读官方文档:
扩展阅读:
 
水平有限,错误欢迎指正。原创博文,转载请注明出处。
 

z-index 基础详解的更多相关文章

  1. javaScript基础详解(1)

    javaScript基础详解 首先讲javaScript的摆放位置:<script> 与 </script> 可以放在head和body之间,也可以body中或者head中 J ...

  2. Dom探索之基础详解

    认识DOM DOM级别 注::DOM 0级标准实际并不存在,只是历史坐标系的一个参照点而已,具体的说,它指IE4.0和Netscape Navigator4.0最初支持的DHTML. 节点类型 注:1 ...

  3. Android中Canvas绘图基础详解(附源码下载) (转)

    Android中Canvas绘图基础详解(附源码下载) 原文链接  http://blog.csdn.net/iispring/article/details/49770651   AndroidCa ...

  4. Python学习一:序列基础详解

    作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/7858473.html 邮箱:moyi@moyib ...

  5. Python学习二:词典基础详解

    作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/7862377.html 邮箱:moyi@moyib ...

  6. 深入浅出DOM基础——《DOM探索之基础详解篇》学习笔记

    来源于:https://github.com/jawil/blog/issues/9 之前通过深入学习DOM的相关知识,看了慕课网DOM探索之基础详解篇这个视频(在最近看第三遍的时候,准备记录一点东西 ...

  7. 三剑客基础详解(grep、sed、awk)

    目录 三剑客基础详解 三剑客之grep详解 1.通配符 2.基础正则 3.grep 讲解 4.拓展正则 5.POSIX字符类 三剑客之sed讲解 1.sed的执行流程 2.语法格式 三剑客之Awk 1 ...

  8. java继承基础详解

    java继承基础详解 继承是一种由已存在的类型创建一个或多个子类的机制,即在现有类的基础上构建子类. 在java中使用关键字extends表示继承关系. 基本语法结构: 访问控制符 class 子类名 ...

  9. java封装基础详解

    java封装基础详解 java的封装性即是信息隐藏,把对象的属性和行为结合成一个相同的独立单体,并尽可能地隐藏对象的内部细节. 封装的特性是对属性来讲的. 封装的目标就是要实现软件部件的"高 ...

  10. 搜索引擎框架之ElasticSearch基础详解(非原创)

    文章大纲 一.搜索引擎框架基础介绍二.ElasticSearch的简介三.ElasticSearch安装(Windows版本)四.ElasticSearch操作客户端工具--Kibana五.ES的常用 ...

随机推荐

  1. vue/vux编译时出现 unexpected token <11:0-485>

    最近开发Vux项目,一直使用VS Code开发工具,可以格式化里面的<script>代码的: 但是今天突然无法格式化代码,而且编译报错.主要提示类似:unexpected token  & ...

  2. 分布式存储系统可靠性系列五:副本放置算法 & CopySet Replication

    本文来自网易云社区 作者:孙建良 在分布式存储系统 中说明了,在一定情况下,copyset的数量不是越多越好,在恢复时间确定的情况下,找到合适的copyset的数量可以降低数据丢失的概率. 在分布式存 ...

  3. Python对文本文件的简单操作(一)

    工作背景 性能测试工程师,主要测试工具--loadrunner,主要是接口测试. 实现功能 loadrunner对报文格式的转换存在问题,部分报文无法转换,故使用Python编写脚本自动将soap协议 ...

  4. Python数据分析基础——读写CSV文件

    1.基础python代码: #!/usr/bin/env python3 # 可以使脚本在不同的操作系统之间具有可移植性 import sys # 导入python的内置sys模块,使得在命令行中向脚 ...

  5. [c++面试准备]--vector对象是如何增长的

    参考资料:cpp primer 5th 背景: 为了支持快速的访问,vector/string将元素连续存储--每个元素都是紧挨着前一个元素存储. 如果我们向vector/string中添加新的元素, ...

  6. [转]/dev/null 命令用法

    /dev/null :代表空设备文件 :代表重定向到哪里,例如:echo "123" > /home/123.txt 1 :表示stdout标准输出,系统默认值是1,所以&q ...

  7. 2015暑假训练(UVALive 5983 - 5992)线段树离线处理+dp

    A: http://acm.hust.edu.cn/vjudge/contest/view.action?cid=83690#problem/A 题意:N*M的格子,从左上走到右下,要求在每个点的权值 ...

  8. col-md-push-*和col-md-offset的区别

    实现方式的区别:col-md-offset-*,是利用margin-left实现的,col-md-push-*/col-md-pull-*是利用相对定位实现的. 效果的区别,col-md-offset ...

  9. POJ 2836:Rectangular Covering(状态压缩DP)

    题目大意:在一个平面内有若干个点,要求用一些矩形覆盖它们,一个矩形至少覆盖两个点,可以相互重叠,求矩形最小总面积. 分析: 数据很小,很容易想到状压DP,我们把点是否被覆盖用0,1表示然后放在一起得到 ...

  10. 逆向中静态分析工具——IDA初学者笔记

    逆向中静态分析工具——IDA初学者笔记 //****************************************************************************** ...