浅谈z-index

本文详细解析了CSS中z-index属性的使用条件及层叠规则,包括与定位元素的关系、层叠上下文的创建以及如何影响子元素的显示层级。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

z-index使用条件

CSS3之前,z-index属性只有和定位元素在(postion不为static的元素)一起的时候才会有作用,但CSS3中flex盒子的子元素也可以设置z-index。理论上来说,数值越大层级越高,然实际上不是

层叠规则

谁大谁上:当具有明显的层叠水平标识的时候,如生效的z-index属性值,在同一个层叠上下文领域,层叠水平值大的那一个覆盖小的那一个
后来居上:当元素的层叠水平一致、层叠顺序相同的时候,在DOM流中处于后面的元素会覆盖前面的元素

在看张鑫旭的《CSS3世界中》:层叠上下文可以嵌套,内层层叠上下文及其所有子元素均受制于外部的层叠上下文
<div style="position:relative; z-index:auto;">
    <!-- 美女 -->
    <img src="1.jpg" style="position:absolute; z-index:2;">  
</div>
<div style="position:relative; z-index:auto;">
    <!-- 美景 -->
    <img src="2.jpg" style="position:relative; z-index:1;">  
</div>

<div style="position:relative; z-index:0;">
    <!-- 美女 -->
    <img src="1.jpg" style="position:absolute; z-index:2;">  
</div>
<div style="position:relative; z-index:0;">
    <!-- 美景 -->
    <img src="2.jpg" style="position:relative; z-index:1;">  
</div>

代码结果:
1347866-20190324195240753-955837069.png

第一个例子父级z-index值为auto,第二个例子父级z-index值为0,仅此不同,然后一个是1在上,一个是2在上,为什么呢?别着急,往下看哈

其实单纯从层叠水平上看,实际上z-index:auto和z-index:0是可以看成一样的,注意我说的是单纯从层叠水平上看,实际上两者在层叠上下文领域有着根本性的差异。
z-index:auto所在的div元素是一个普通定位元素,于是他们的子级层叠比较就不受父级影响,两者直接遵循我们上面提到的层叠准则:“谁大谁上”,所以第一个元素的子级z-index:2比第二个元素的子级z-index:1大,所以第一个div就在上面显示

注意:当我们为元素设置了定位(除值为static外),但没有为其设置z-index时,就默认z-index值为auto

而z-index一旦变成数值,哪怕是0,就会创建一个层叠上下文,此时层叠规则就发生了变化,层叠上下文是自成体系的,当元素发生层叠的时候,整个元素被认为是在父层叠上下文的层叠顺序中。所以两个子级的div层叠顺序比较变成了优先比较其父级层叠上下文元素的层叠顺序。这里由于外面两个div元素都是z-index:0;两者的层叠顺序一样大,此时遵循层叠原则中的“后来居上”,根据在DOM文档流中的位置决定谁在上面,于是2就在上面了,所以此时子元素的z-index没有起作用

参考书籍:
张鑫旭《CSS世界》

转载于:https://www.cnblogs.com/raind/p/10589977.html

<think>嗯,用户问的是一次请求的全过程,这应该是想了解从客户端发起请求到服务器响应并返回数据的整个流程。首先,我需要回忆一下网络通信的基本模型,比如OSI七层模型或者TCP/IP四层模型。然后,考虑从用户输入网址开始,DNS解析、建立TCP连接、发送HTTP请求、服务器处理、返回响应、浏览器渲染这些步骤。可能还需要细分每个步骤的具体过程,比如三次握手、TLS握手如果是HTTPS的话。同时要注意用户可能是开发者或者普通用户,但问题比较基础,可能不需要太深入的技术细节,但需要准确。 用户提到使用中文回答,所以要注意用词准确且易懂。系统级指令里要求数学表达式用$...$,不过这个问题可能不涉及数学公式,但需要留意。结构要清晰,分步骤说明,可能用序号列出每个阶段,再详细展开。比如: 1. DNS解析:将域名转换为IP地址,涉及到本地缓存、递归查询等。 2. 建立TCP连接:三次握手的过程,客户端发送SYN,服务器SYN-ACK,客户端ACK。 3. 发送HTTP请求:GET/POST等方法,请求头和正文。 4. 服务器处理:Web服务器(如Nginx)转发到应用服务器,处理逻辑,访问数据库等。 5. 返回HTTP响应:状态码、响应头、数据(HTML/JSON等)。 6. 浏览器渲染:解析HTML、CSS,执行JavaScript,构建DOM树等。 需要检查是否每个步骤都覆盖到了关键点,有没有遗漏,比如可能还有TLS握手在HTTPS的情况下,或者负载均衡、CDN的环节。同时要确保流程正确,比如DNS解析是在TCP连接之前,而TLS握手是在TCP连接之后。可能还要提到缓存机制,比如浏览器缓存、CDN缓存等对请求过程的影响。 另外,用户可能对某些术语不太了解,需要适当解释,比如DNS是什么,三次握手的目的,状态码的意义等。但保持简洁,不过于深入。最后,总结整个流程,让用户有一个整体的认识。需要确保语言流畅,逻辑清晰,步骤正确,没有技术错误。</think>一个完整的网络请求(例如访问网页)通常经历以下阶段,以访问 `https://example.com` 为例: --- ### 一、DNS 解析 1. **浏览器缓存**:检查本地是否缓存过域名对应的 IP 地址。 2. **系统缓存**:若未命中,查询操作系统 hosts 文件。 3. **递归查询**:向本地 DNS 服务器(如 ISP 提供)发起请求,逐级查询根域名服务器、顶级域名服务器(`.com`),最终获得 `example.com` 的 IP 地址。 --- ### 二、建立 TCP 连接 1. **三次握手**: - 客户端发送 `SYN` 包(同步请求)。 - 服务器返回 `SYN-ACK` 包(确认同步)。 - 客户端回复 `ACK` 包(最终确认),连接建立。 --- ### 三、TLS 握手(仅 HTTPS) 1. **协商加密协议**:客户端发送支持的 TLS 版本和密码套件。 2. **证书验证**:服务器返回 SSL 证书,客户端验证其合法性(如颁发机构、有效期)。 3. **生成会话密钥**:通过非对称加密交换密钥,后续通信使用对称加密。 --- ### 四、发送 HTTP 请求 1. **构造请求报文**: ```http GET /index.html HTTP/1.1 Host: example.com User-Agent: Chrome/... ``` 2. **传输数据**:通过已建立的 TCP 连接发送请求头和正文(如 POST 请求)。 --- ### 五、服务器处理请求 1. **反向代理**:Web 服务器(如 Nginx)接收请求,可能转发到应用服务器(如 Tomcat)。 2. **业务逻辑**:应用服务器执行代码(如查询数据库、调用 API)。 3. **生成响应**:服务器返回状态码(如 `200 OK`)和内容(如 HTML、JSON)。 --- ### 六、浏览器解析与渲染 1. **解析 HTML**:构建 DOM 树。 2. **加载资源**:下载 CSS、JavaScript 和图片等。 3. **执行脚本**:运行 JavaScript,修改 DOM/CSSOM。 4. **渲染页面**:合成布局(Layout)、绘制(Paint)到屏幕。 --- ### 七、连接释放 1. **四次挥手**: - 客户端发送 `FIN` 包。 - 服务器回复 `ACK` 包。 - 服务器发送 `FIN` 包。 - 客户端回复 `ACK` 包,连接关闭。 --- ### 流程图总结 $$ \begin{aligned} &\text{客户端} \xrightarrow{\text{DNS查询}} \text{IP地址} \xrightarrow{\text{TCP三次握手}} \text{服务器} \\ &\xrightarrow{\text{HTTPS握手}} \text{加密通道} \xrightarrow{\text{HTTP请求/响应}} \text{数据交互} \\ &\xrightarrow{\text{渲染}} \text{页面展示} \xrightarrow{\text{TCP四次挥手}} \text{连接终止} \end{aligned} $$ 此过程涉及网络协议栈、服务器架构和浏览器工作原理的协同,实际场景可能包含 CDN、负载均衡等优化环节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值