CSS3笔记之定位篇(二)z-index

知识点1:z-index基础

  •   z-index:auto; 默认值
  •   z-index: <integer>  整数
  •   z-index: inherit 继承
  •   不考虑css3  还有定位元素的z-index才有作用

知识点2:z-index与定位元素

  •   无嵌套:后来居上,哪个大哪个上
//在没有添加z-index属性时,如果两个图片有重叠,默认为图片2覆盖图片1   “后来居上”
//如果添加了z-index,则那个元素的z-index值大,那个在最上面    “哪个大哪个上”
<img src="图片1" style="position: relative; z-index: 2">
<img src="图片2" style="position: absolute; z-index: 1">
  •   有嵌套:祖先优先原则(z-index: 数字)
//虽然图片1的z-index大于图片2的z-index,但是对于嵌套的定位元素z-index遵循祖先优先原则,所以图片2优先显示
<div style="position: relative; z-index: 1"> //祖先元素的z-index不能为auto<img src="图片1" style="position: relative; z-index: 2">      
</div>
<div style="position: relative; z-index: 1"> //祖先元素的z-index不能为auto<img src="图片2" style="position: absolute; z-index: 1">      
</div>

知识点3:层叠上下文(stacking-context)和层叠水平(stacking-level)(重要)

  •   层叠上下文:

      页面根元素天生具有层叠上下文,称之为“根层叠上下文”

    z-index值为数值的定位元素也具有层叠上下文

    其他属性

  •   层叠水平:层叠上下文中的每一个元素都有一个层叠水平,决定了同一个层叠上下文中元素在z轴上的显示顺序
  •   层叠水平和z-index不是一个东西,普通元素也有层叠水平。
  •   层叠上下文的特性:
  1. 层叠上下文可以嵌套,组合成一个分层次的层叠上下文。

  2. 每个层叠上下文和兄弟元素独立:当进行层叠变化或渲染的时候,只需要考虑后代元素。

  3. 每个层叠上下文是自成体系的:当元素的内容被层叠后,整个元素被认为是在父层的层叠顺序中。

知识点4:层叠顺序 (stacking-order)
  background --> 负z-index --> block块状水平盒子 --> float浮动盒子 --> inline/inline-block
  --> z-index:auto或z-index:0 --> 正z-index

知识点5:z-index与层叠上下文

  •   定位元素默认z-index:auto可以看成z-index:0
  •   z-index不为auto的定位元素会创建层叠上下文
  •   z-index层叠顺序的比较止步于父级层叠上下文

知识点6:其他css属性与层叠上下文

  •  能创建层叠上下文的的css属性
<div class="box"><div><img src="logo.jpg"></div>
</div>
<style>.box {display: flex;                     // 1.display: flex 与子元素z-index不为auto 配合使用background:blue}.box > div {z-index: 1}.box > div > img {position: relative; z-index: -1;}
</style><div class="box"><img src="" alt="">
</div>
<style>.box {background:blue;opacity: .5;                       // 2.opacity 不等于 1transform: rotate(15deg);          // 3.transform 不等于 nonemix-blend-mode: screen;            // 4.mix-blend-mode: screenfilter: blur(5px);                 // 5.filter 不等于 noneisolation: isolate;                // 6.isolation: isolateposition: fixed;                   // 7.position: fixed Chrome等bink/webkit内核的浏览器使用will-change: transform;            // 8.will-change: transform-webkit-overflow-scrolling: touch  // 9.移动端}.box > div > img {position: relative; z-index: -1;}
</style>

知识点7:z-index与其他css属性层叠上下文

background --> 负z-index --> block块状水平盒子 --> float浮动盒子 --> inline/inline-block
  --> z-index:auto或z-index:0,不依赖z-index的层叠上下文 --> 正z-index

不支持z-index的层叠上下文元素的层叠顺序均是z-index:auto级别;

依赖z-index值创建层叠上下文的情况:

  1. position值为relative/absolute或fixed(部分浏览器)

  2. display:flex/inline-flex容器的子flex项

知识点8:z-index相关实践分享

  • 最小化影响原则 

  目的:避免z-index嵌套层叠关系混乱 
  原因:
    1. 元素的层叠关系主要由所在的层叠上下文决定 
    2. IE7 中z-index为auto也会创建层叠上下文
  做法:
    1. 避免使用定位属性
    2. 定位属性从大容器平级分离为私有小容器

  • 不犯二准则 

  目的:避免z-index混乱,出现一山又比一山高的样式问题
  原因:多个协作以及后期维护
  做法:对于任何非浮层元素,避免设置z-index值,z-index值没有任何道理需要超过2

  • 组件层级计数器

  目的:避免浮层组件因z-index被覆盖的问题 
  原因:
    1. 总会遇到意想不到的高层及元素
    2. 组件的覆盖规则具有动态性
  做法:组件层级计数器方法 (JS获取最大z-index,再加1)

  • 可访问性隐藏:人肉眼不可见,但是辅助设备可以识别。

  z-index负值元素在层叠上下文的背景之上,其他元素之下

  


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/249361.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JSP页面传值出现中文乱码的问题

在接收值的jsp页面代码的body里添加&#xff1a; <%request.setCharacterEncoding("utf-8"); %> //这里是设置utf-8为jsp页面的中文编码方式 jsp页面之间传值&#xff1a; 发送信息的jsp脚本&#xff1a; session.setAttribute("user",rs.getString…

【我所认知的BIOS】— uEFI AHCI Driver(8) — Pci.Read()

【我所认知的BIOS】—> uEFI AHCI Driver(8) — Pci.Read()LightSeed6/19/2014社会一直在变。不晓得是不是社会变的太苦开&#xff0c;而我没变所以我反而显得单纯了。办一个居住证。几年前办的以为最终能够一劳永逸的&#xff0c;后来续办的是发现确实不难了。尼玛&#xf…

springboot项目集成vue

vue的项目目录如下&#xff1a; vue项目打包 首先进入项目目录&#xff1a;cd 项目名 然后执行打包命令&#xff1a;npm run build随后我们的项目中会多出一个dist文件夹&#xff1a;如下图 然后将dist文件夹中的所有内容放到eclipse中的src/main/resources/static文件夹里面…

Vue项目启动webpack报错Module build failed: Error: No PostCSS Config found in......

自己写的公司项目&#xff0c;今天需要提交到公司版本库&#xff0c;可是在本地启动正常的项目&#xff0c;拷贝到git文件目录下突然报错Module build failed: Error: No PostCSS Config found in......&#xff0c;源文件都没有改动过&#xff01; 然后自己各种百度&#xff…

2.1对 特征归一化 的一些理解

特征归一化有很多不同的叫法&#xff0c;比如&#xff1a;特征缩放&#xff0c;Feature Normalization&#xff0c;Feature Scaling 数据标准化&#xff08;归一化&#xff09;处理是数据挖掘的一项基础工作&#xff0c;不同评价指标往往具有不同的量纲和量纲单位&#xff0c;这…

逆向工程生成的Mapper.xml以及*Example.java详解

逆向工程生成的接口中的方法详解 在我上一篇的博客中讲解了如何使用Mybayis逆向工程针对单表自动生成mapper.java、mapper.xml、实体类&#xff0c;今天我们先针对mapper.java接口中的部分方法进行测试&#xff0c;以了解其作用。 先看表结构。。。 从下图可以看到MBG根据数据表…

SpringBoot之静态资源访问

SpringBoot之静态资源访问 1.springboot访问静态资源的几种方式 (1)在src/main/resources/目录下创建 static文件夹 (2)在src/main/resources/目录下创建 resources文件夹 (3)在src/main/resources/目录下创建 public文件夹 (4)在src/main/resources/目录下创建 META-INF/resou…

几何

题目大意定义一个$S-$四面体表示六条边由$S$根不同的木棍组成&#xff0c;定义一种染色方法合法当且仅当至少有$S$根木棍被染色且与每个顶点相邻的三根木棍中至多有一根被染色&#xff0c;求有$N$个$S1,2...N$四面体&#xff0c;求至少染$K$个的方案数。 题解 单独考虑$S1$四面…

VUE的element-ui的使用

我们在自己的网站当中有的时候会用到element-ui的组建 1.如何安装element-ui的组件 在命令行工具当中输入cnpm i element-ui -S, 等待安装 2.如何在vue当中使用element-ui的组件 1.在main.js中引入element相关的js和cssimport Vue from vueimport ElementUI from element-u…

NodeJS+Express+Mysql+MongoDB之环境配置

node作为一款可以兼容前后端的js语言,在做持久层操作上和Java比较类似,下面就简单介绍一下项目中的数据库配置操作. 首选使用express框架自动创建一个测试项目,并在目录下建立一个专门存放数据库配置的配置文件,比如:db.js 代码如下 /* * 数据库配置文件 * Author: zth * D…

Python 私有变量的访问和赋值

首先我们这里先描述下&#xff1a;  Python中&#xff0c;变量名类似__x__的&#xff0c;以双下划线开头&#xff0c;并且以双下划线结尾的&#xff0c;是特殊变量&#xff0c;特殊变量是可以直接访问的&#xff08;比如 __doc__, __init__等&#xff09;&#xff0c;不是pri…

SpringBoot入门教程(一)详解intellij idea搭建SpringBoot

最近公司有一个内部比赛(黑客马拉松)&#xff0c;报名参加了这么一个赛事&#xff0c;在准备参赛作品的同时&#xff0c;由于参赛服务器需要自己搭建且比赛产生的代码不能外泄的&#xff0c;所以借着这个机会&#xff0c;本地先写了个测试的demo&#xff0c;来把tomcat部署相关…

文艺平衡树 Splay 学习笔记(1)

&#xff08;这里是Splay基础操作&#xff0c;reserve什么的会在下一篇里面讲&#xff09; 好久之前就说要学Splay了&#xff0c;结果苟到现在才学习。 可能是最近良心发现自己实在太弱了&#xff0c;听数学又听不懂只好多学点不要脑子的数据结构。 感觉Splay比Treap良心多了—…

JS使用XMLHttpRequest对象POST收发JSON格式数据

JavaScirpt中的XMLHttpRequest对象提供了对 HTTP 协议的完全访问&#xff0c;使用该对象可以在不刷新页面的情况与服务器交互数据。XMLHttpRequest是实现AJAX技术的关键对象&#xff0c;本站曾整理过一篇介绍该对象的文章&#xff1a; JS使用XMLHttpRequest对象与服务器进行数据…

ShopXO本地化部署安装之centeros 安装Apache2.4.6 + PHP7.0.33 + Mysql5.7.25环境

对于centerOS安装PHP环境&#xff0c;目前网上的帖子都已经比较成熟&#xff0c;具体步骤大家可以自行搜索查看&#xff0c;但是在安装过程中遇到的一些小细节&#xff0c;这些内容往往需要结合多个帖子才能找到答案&#xff0c;在这里简单记录一下。 细节一 如果使用的阿里云…

Spring Boot 扩展点应用之工厂加载机制

Spring 工厂加载机制&#xff0c;即 Spring Factories Loader&#xff0c;核心逻辑是使用 SpringFactoriesLoader 加载由用户实现的类&#xff0c;并配置在约定好的META-INF/spring.factories 路径下&#xff0c;该机制可以为框架上下文动态的增加扩展。 该机制类似于 Java SPI…

Vue.js使用-http请求

Vue.js使用-ajax使用 1.为什么要使用ajax 前面的例子&#xff0c;使用的是本地模拟数据&#xff0c;通过ajax请求服务器数据。 2.使用jquery的ajax库示例 new Vue({el: #app,data: {searchQuery: ,columns: [{name: name, iskey: true}, {name: age},{name: sex, dataSource:…

跨域(Cross-Domain) AJAX for IE8 and IE9

1、有过这样一段代码&#xff0c;是ajax $.ajax({url: "http://127.0.0.1:9001",type: "POST",data: JSON.stringify({"reqMsg":"12345"}),dataType: json,timeout: 1000 * 30,success: function (response) {if(response.n6){dosomet…

移动WEB的页面布局

随着移动互联网的日益普遍&#xff0c;现在移动版本的web应用也应用而生&#xff0c;那么在做移动web页面布局的过程中&#xff0c;应该注意哪些要点呢&#xff1f;现把个人的一些学习经验总结如下&#xff1a; 要点一、piexl 1px 2dp dp dpr dpi ppi 要点二、viewport io…

AnswerOpenCV(1001-1007)一周佳作欣赏

外国不过十一&#xff0c;所以利用十一假期&#xff0c;看看他们都在干什么。一、小白问题http://answers.opencv.org/question/199987/contour-single-blob-with-multiple-object/ Contour Single blob with multiple objectHi to everyone. Im developing an object shape id…