移动端的绝世之坑1(求大神解答)

无论怎么设置其堆叠次序,绝对定位的元素都无法盖住和自己平行的一个元素。直接上代码和效果图

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<meta name="viewport" content="user-scalable=no"/>

		<style>
			body{margin:0;position:fixed;transform:rotate(90deg);width:100vh;height:100vw;transform-origin:50vw 50%;}
			#container{overflow:hidden;position:relative;}
			#content{height:330px;}
			#ele_cont{height:220px;overflow:scroll;}
			#ele{height:221px;background:#ddf;}
			#mask{width:100%;height:100%;top:0;left:0;background: #afa;position:absolute;}
		</style>
	</head>
	<body>
		<div id="container">
			<div id="ele_cont">
				<div id="ele"></div>
			</div>
			<div id="mask"></div>
		</div>
	</body>
</html>

 我给#ele_cont的overflow设置的是scroll,总感觉和这个有点关系。多次尝试后发现,这件事发生的必要条件是:

1、#ele_cont要溢出

2、#container的overflow必须是hidden或scroll

3、body必须是旋转90度,其他任何角度均无效

4、必须在移动端调试看,PC端无效

后来,我又怀疑,#ele_cont溢出使里面的#ele的堆叠次序上升了,于是降低其堆叠次序,发现也产生效果了。直接上代码和效果图

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<meta name="viewport" content="user-scalable=no"/>

		<style>
			body{margin:0;position:fixed;transform:rotate(90deg);width:100vh;height:100vw;transform-origin:50vw 50%;}
			#container{overflow:hidden;position:relative;}
			#content{height:330px;}
			#ele_cont{height:220px;overflow:scroll;}
			#ele{height:221px;background:#ddf;z-index:-1;position:relative;}
			#mask{width:100%;height:100%;top:0;left:0;background: #afa;position:absolute;}
		</style>
	</head>
	<body>
		<div id="container">
			<div id="ele_cont">
				<div id="ele"></div>
			</div>
			<div id="mask"></div>
		</div>
	</body>
</html>

 

能发现这种奇怪的现象纯属巧合,还请大神们帮忙看下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值