详解CSS的z-index属性(带图片解析)

有时候我们会使用CSS中的z-index属性来使某些块状元素更有层次感。

如下图:可以通过z-index实现鼠标居于文字后面,使得网页更有层次感


实现上面效果的代码如下:

[html]  view plain  copy
  1. <span style="font-size:24px;"><html>  
  2. <head>  
  3. <style type="text/css">  
  4. img.x  
  5. {  
  6. position:absolute;  
  7. left:0px;  
  8. top:0px;  
  9. z-index:-1  
  10. }  
  11. </style>  
  12. </head>  
  13.   
  14. <body>  
  15. <h1>这是一个标题</h1>  
  16. <img class="x" src="/i/eg_mouse.jpg" />   
  17. <p>默认的 z-index 是 0。Z-index -1 拥有更低的优先级。</p>  
  18. </body>  
  19.   
  20. </html>  
  21. </span>  

但是好多刚学习css的新手们,会对z-index属性有些不解,明明自己设置了z-index属性,但是问什么看不到任何效果呢?

要解决这个问题就要去w3c上去看下官方定义:



这里需要特别说明的是:Z-index只能工作在被明确定义了absolute,fixed或relative 这三个定位属性的元素中,如果没有定义position属性,则z-index属性不起作用。

所以Z-index 仅能在定位元素上奏效(例如 position:absolute;)

用下面的代码和图解来给大家做一下对比:


1,代码中没有定义position属性

[html]  view plain  copy
  1. <span style="font-size:24px;"><!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4.     <title>学习认识z-index</title>  
  5.     <meta charset="utf-8">  
  6.     <style type="text/css">  
  7.         #box{  
  8.             width: 1000px;  
  9.             height:1000px;  
  10.             border: 1px royalblue solid;  
  11.         }  
  12.         #box1{  
  13.             background-color: red;  
  14.             width: 200px;  
  15.             height: 200px;  
  16.             z-index: 999;  
  17.   
  18.   
  19.         }  
  20.         #box2{  
  21.             background-color: yellow;  
  22.             width: 200px;  
  23.             height: 200px;  
  24.             margin-left: 150px;  
  25.             z-index: 99;  
  26.         }  
  27.         #box3{  
  28.             background-color: green;  
  29.             width: 200px;  
  30.             height: 200px;  
  31.             margin-left: 300px;  
  32.             z-index: 9;  
  33.   
  34.   
  35.         }  
  36.   
  37.   
  38.     </style>  
  39. </head>  
  40. <body>  
  41. <div id="box">  
  42.     <div id="box1">  
  43.         <span >我的z-index为999</span>  
  44.     </div>  
  45.     <div id="box2">  
  46.         <span >我的z-index为99</span>  
  47.     </div>  
  48.     <div id="box3">  
  49.         <span >我的z-index为9</span>  
  50.     </div>  
  51. </div>  
  52. </body>  
  53. </html>  
  54. </span>  

显示结果如下图:


从上图中我们可以看出,明明我们设置了z-index属性,但是为什么没有出现任何层叠效果呢?这也就是大多数新手会遇到的问题,这时我们就要认证去W3C阅读关于z-index的规则了,在上面的W3C规则中有一句话,大家一定要谨记:“Z-index 仅能在定位元素上奏效(例如 position:absolute;)”

下面我们就在代码中加上position:absolute;属性来看看显示效果:


2,定义了position:absolute;属性的代码:

[html]  view plain  copy
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4.     <title>学习认识z-index</title>  
  5.     <meta charset="utf-8">  
  6.     <style type="text/css">  
  7.         #box{  
  8.             width: 1000px;  
  9.             height:1000px;  
  10.             border: 1px royalblue solid;  
  11.         }  
  12.         #box1{  
  13.             background-color: red;  
  14.             width: 200px;  
  15.             height: 200px;  
  16.             z-index: 999;  
  17.   
  18.             position: absolute;  
  19.   
  20.         }  
  21.         #box2{  
  22.             background-color: yellow;  
  23.             width: 200px;  
  24.             height: 200px;  
  25.             margin-left: 150px;  
  26.             z-index: 99;  
  27.   
  28.             position: absolute;  
  29.         }  
  30.         #box3{  
  31.             background-color: green;  
  32.             width: 200px;  
  33.             height: 200px;  
  34.             margin-left: 300px;  
  35.             z-index: 9;  
  36.   
  37.             position: absolute;  
  38.         }  
  39.     </style>  
  40. </head>  
  41. <body>  
  42. <div id="box">  
  43.     <div id="box1">  
  44.         <span >我的z-index为999</span>  
  45.     </div>  
  46.     <div id="box2">  
  47.         <span >我的z-index为99</span>  
  48.     </div>  
  49.     <div id="box3">  
  50.         <span >我的z-index为9</span>  
  51.     </div>  
  52. </div>  
  53. </body>  
  54. </html>  

这时我们就看到了如下图所示的层叠效果。



综上所述,我为大家做出了如下的总结,供大家参考。

CSS中z-index属性
1,定义和用法
z-index 属性设置元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。
注释:元素可拥有负的 z-index 属性值。
注释:Z-index 仅能在定位元素上奏效(例如 position:absolute;),
注意:Z-index只能工作在被明确定义了absolute,fixed或relative 这三个定位属性的元素中,如果没有定义position属性,则z-index属性不起作用。
2,说明
该属性设置一个定位元素沿 z 轴的位置,z 轴定义为垂直延伸到显示区的轴。如果为正数,则离用户更近,为负数则表示离用户更远。

通俗讲就是z-index的值越大,就离我们越近,显示的就靠前。




原文地址:http://blog.csdn.net/qiushi_1990/article/details/40716833

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
z-indexCSS属性之一,用于控制元素在层叠上下文中的显示顺序。未设置z-index属性的元素会采用默认值0,而设置了z-index属性的元素可以通过属性值的大小来确定其层级关系。 当设置了z-index属性的元素的属性值大于0时,该元素的层级会高于未设置z-index属性的元素。这意味着具有较高属性值的元素会覆盖在较低属性值的元素之上。 然而,z-index受限于层叠上下文的影响。即使一个元素具有较高的z-index属性值,但如果它所属的层叠上下文的z-index值小于其他元素所属层叠上下文的z-index值,那么它仍然会处于下方。因此,层叠上下文的z-index值比元素自身的z-index值更重要。 另外,当设置了z-index属性的元素的属性值为0时,它与未设置z-index属性的元素层级相同,遵循后面的元素覆盖前面元素的规则。 总结来说,z-index属性用于控制元素在层叠上下文中的层级关系,较高的属性值会覆盖较低的属性值,但受限于层叠上下文的影响。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [CSSz-index 属性详解](https://blog.csdn.net/weixin_45092437/article/details/126493240)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [CSS深入理解z-indexz-index相关知识总结)](https://blog.csdn.net/qq_41000891/article/details/110005863)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值