父元素transform,子元素fixed相对body失效

position属性:

absolute生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。元素的位置通过 “left”, “top”, “right” 以及 “bottom” 属性进行规定。
fixed生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 “left”, “top”, “right” 以及 “bottom” 属性进行规定。
relative生成相对定位的元素,相对于其正常位置进行定位。
static默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。
inherit规定应该从父元素继承 position 属性的值。

需求:父元素居中,子元素覆盖body的蒙版
原代码:

<div calss='fater'>
	<div class='loading'></div>
</div>
.fater{
	width:1024px;
	height:100vh;
	position:absolute;
	transform:translate(-50%,-50%)
}
.loading{
	postion:fixed;
	width:100vw;
	height:100vh;
	top:0;
	background:rgba(255,255,255,.84)
}

loading并没有覆盖body而是覆盖了father
原因:父级元素使用tranform,子元素使用fixed,子元素会变成相对于父级元素定位

修改后代码

<div calss='fater'>
	<div class='loading'></div>
</div>
.fater{
	width:1024px;
	height:100vh;
	margin:0 auto;
}
.loading{
	postion:fixed;
	width:100vw;
	height:100vh;
	top:0;
	background:rgba(255,255,255,.84)
}

!!!以上

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值