层叠级别和z-index

z-index :auto|< integer > auto 默认值
定义:一个元素在文档中的层叠顺序,用于确认元素在当前层叠上下文中的层叠级别。
适用于:定位元素。即定义了position为非static的元素
每个元素层叠顺序由所属的层叠上下文和元素本身的层叠级别决定(每个元素仅属于一个层叠上下文)。

  1. 同一层叠上下文

层叠级别大的显示在上面,级别小的显示在下面;

层叠级别中的两个元素,依据它们在HTML文档流中的顺序,写在后面的将会覆盖前面的。

  1. 不同层叠上下文

元素的显示顺序依据祖先的层叠级别来决定,与自身的层叠级别无关。

例:

  1. 有两个div盒子,a、c在一个盒子里,b在另一个盒子里,来考虑其z-index是不是正常效果。
<body>  
    <div>  
        <p class="a">a</p>  
        <p class="c">c</p>  
    </div>  
    <div>  
        <p class="b">b</p>  
    </div>  
</body>  

div未设置z-index,在高级浏览器下不会产生新的局部层叠上下文,也就是说它们的子元素没有被新的局部层叠上下文包裹,那么它们的子元素就处在同一个层叠上下文中,可以直接通过自身的层叠级别来决定显示顺序。

	div {  
       position: relative;  
       width: 100px;  
       height: 100px;  
    }  
	  p {  
       position: absolute;  
       font-size: 20px;  
       width: 100px;  
       height: 100px;  
    }  
	 .a {  
  		background-color: pink;  
   		z-index: 1;  
    }  
	          
	 .c {  
       background-color: green;  
       z-index: 2;  
       top: 20px;  
       left: 20px;  
    }  
	 .b {  
       background-color: red;  
       z-index: 3;  
       top: -20px;  
       left: 40px;  
    }  

a、b、c处于一个层叠上下文中,所以根据z-index大小来确定层级。如下图所示:
在这里插入图片描述

  1. 有两个div盒子,a、c在一个盒子里,b在另一个盒子里,来考虑其z-index是不是正常效果。
<body>
	<div class="box1">
		<p class="a">a</p>
		<p class="c">c</p>
	</div>
	<div class="box2">
		<p class="b">b</p>
	</div>
</body>

div设置z-index,那么div中的子元素以父元素的层叠关系为主。

<style type="text/css">
		div {
			width: 100px;
			height: 100px;
			position: relative;
		}
		.box1 {
			z-index: 2;
		}
		.box2 {
			z-index: 1;
		}
		p {
			position: absolute;
			font-size: 20px;
			width: 100px;
			height: 100px;
		}
		.a {
			background-color: red;
		}
		.c {
			background-color: green;
			top: 20px;
			left: 20px;
		}
		.b {
			background-color: blue;
			top: -20px;
			left: 40px;
			z-index: 20;
		}
	</style>

a、b、c处于不同的层叠上下文中,所以根据父级的z-index大小来确定层级。如下图所示:
在这里插入图片描述
由上,可以看出z-index的决定方式:所属的层叠上下文和元素本身的层叠级别

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值