z-index的作用

很多时候需要把一个元素覆盖到另一个元素之上,比如登入弹出框等,这个时候就需要z-index属性出场了。所以呢,z-index就是调节层的显示优先级,决定哪个显示在最上方。作用范围就是Positioned element,比如绝对定位,相对定位,固定定位。

层叠上下文(The stacking context)中的z-index

先看下面的关系图:
 
这是效果:
 
 
 
我们会发现虽然DIV4的index最大,但是它还是被别的元素覆盖了,这是为什么呢?
 
简单的理解就是z-index在不同的地方有不同的权重,在最高级(root)权重最高,相邻元素(sibling)嵌套一层权重就低一级。对于上面的例子我们可以这么计算:
  1. DIV1--->5
  2. DIV2--->2
  3. DIV3--->4
  4. DIV4--->4.6
  5. DIV5--->4.1
  6. DIV6--->4.3
这样计算一般的z-index嵌套就OK啦。

不用z-index的堆叠(stacking)

两条原则:
  1. 没有指定z-index值的positioned element,他们的堆叠顺序取决于在HTML文档中的顺序,越靠后出现的元素,位置越高;
  2. 非positoned element元素,不管在HTML中出现的顺序如何,总是在positioned element元素下方;
例子:

层叠与浮动之间的关系

non-positioned block的背景和边界没有被浮动元素影响,但是元素中的内容被浮动元素影响了(浮动布局的之后注意这个特性)。
 
层叠顺序:
  1. 根元素的背景和边界;
  2. 在普通流中的子代元素;
  3. 浮动元素;
  4. 普通流中的内联子代元素;
  5. 定位了的元素;
例子:

z-index数值分配

随便打开一个网站的首页,查看源码之后发现,z-index的数值乱七八糟,那应该怎么用合适呢?
 
我采取的办法是,把100设置为1档,如果需要堆叠三个层,从上到下分别是DIV3,DIV2,DIV1。那么DIV1的z-index赋值为100,DIV2的z-index赋值为200,DIV3的z-index赋值为300,这样如果将来在DIV1和DIV2之间加入一层的话还有很多余量可以选择。如果三个之间不留空隙的话以后插入一个新层就不方便啦。这样还有一个好处,就是通过查看z-index的数值可以很方便的判断当前元素位于哪一层。

既定位了然后也浮动

浮动和相对定位可以一起使用;
浮动和绝对定位不能一起使用(浮动不起任何作用)。

参考:

关于z-index的总结的更多相关文章

  1. 运用<div>布局页面练习

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. 关于Cewu Lu等的《Combining Sketch and Tone for Pencil Drawing Production》一文铅笔画算法的理解和笔录。

     相关论文的链接:Combining Sketch and Tone for Pencil Drawing Production 第一次看<Combining Sketch and Tone f ...

  3. 四种比较简单的图像显著性区域特征提取方法原理及实现-----> AC/HC/LC/FT。

    laviewpbt  2014.8.4 编辑 Email:laviewpbt@sina.com   QQ:33184777 最近闲来蛋痛,看了一些显著性检测的文章,只是简单的看看,并没有深入的研究,以 ...

  4. C# 金钱 小写转大写的算法

    调用 ConvertMoney的ConvertMoneyToWords(decimal money)方法即可 using System; using System.Collections.Generi ...

  5. 【Unity3D】利用Shader以及更改Mesh实现2D游戏的动态阴影效果

    最近看到一个非常有趣的益智小游戏,是一个盗贼进入房子偷东西的, 其实这种游戏市面上已经很多了,吸引我的是那个类似手电筒的效果, 主角走到哪里,光就到哪里,被挡住的地方还有阴影.有点类似策略游戏里的战争 ...

  6. 来看看css3中的box-shadow

    不谈IE,只谈谈box-shadow的具体使用方法 语法: E {box-shadow: <length> <length> <length>?<length ...

  7. img和css背景的选择

    在什么情况下更适合使用HTML IMG标签来显示一个图像,而不是一个CSS有背景图像,反之亦然? 如下场景使用img标签比较合适: 1.如果图像是等内容的一部分或图表或人(真正的人,而不是股票图人), ...

  8. 深入理解CSS中的层叠上下文和层叠顺序(转)

    by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wordpress/?p=5115 零.世间的道 ...

  9. 2016 年青岛网络赛---Family View(AC自动机)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=5880 Problem Description Steam is a digital distribut ...

  10. 你知道吗?Web的26项基本概念和技术

    这是我在网上看到一篇不错的文章,拿出来与大家分享一下:希望有所帮助 作者: 小鱼  来源: 前端里  发布时间: 2014-08-01 22:56  阅读: 10477 次  推荐: 51   原文链 ...

随机推荐

  1. CodeForces 589I Lottery (暴力,水题)

    题意:给定 n 和 k,然后是 n 个数,表示1-k的一个值,问你修改最少的数,使得所有的1-k的数目都等于n/k. 析:水题,只要用每个数减去n/k,然后取模,加起来除以2,就ok了. 代码如下: ...

  2. cookie.js 加载顺序问题

    今天遇到一个问题,在使用cookie.js时,只有在jquery.js文件后加载整体才有效 有效加载顺序 <head> <script type="text/javascr ...

  3. [置顶] a+=1/a=+1/a-=1区别-c语言

    1.解释 a+=1/a=+1/a-=1 含义 a+=1 实质等于 a += 1,也就是等于 a = a + 1: a=+1 实质等于 a = +1:[因为运算符中没有=+,很多人误以为是 a =+ 1 ...

  4. MFC 视图、文档、框架(通讯)

    CMainFrame * pMainWnd=(CMainFrame*)AfxGetApp()->m_pMainWnd;//主框架 CChildFrame * pChild = (CChildFr ...

  5. Centos7安装Docker Engine

    一.先决条件 首选需要一个64位操作系统和3.10或者更版本的内核. 查看当前内核版本: $ uname -r -.el7.x86_64 二.yum安装Docker Engine 安装Docker E ...

  6. velocity 快速入门

    基本语法      1.变量定义 : $name 注意 : a.名字和$配合一起用  b.更规范的写法是 ${name} 2.赋值 : #set($name = "威少") 3.条 ...

  7. 基于EF的数据外键关联查询

    现在很多ORM不自带外键关联的实体查询,比如我查询用户,用时将关联的角色信息查询出来,那么就要进行2次查询,很麻烦.而我现在要做的就是基于EF的外键关联查询.很方便的. 首先,创建基础查询的BaseS ...

  8. sql2008“备份集中的数据库备份与现有数据库不同”解决方法

    因为是在另一台电脑对同名数据库做的备份,用常规方法还原,提示不是相同数据库,不让还原,在网上找到下面的方法解决了: 一.右击系统数据库master,新建查询 执行以下SQL代码: RESTORE DA ...

  9. Install eclipse groovy plugin

    http://dist.springsource.org/release/GRECLIPSE/e4.4/

  10. Codeforces Gym 100431G Persistent Queue 可持久化队列

    Problem G. Persistent QueueTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudg ...