H5在微信端锁定背景滚动

当在微信浏览器中打开H5页面时,如果不做处理,即使页面顶部,背景仍可滚动。通过阻止默认滚动事件、设置overflow属性以及利用CSS固定定位等方式,可以有效解决在iOS和Android设备上背景滚动问题。

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

在微信浏览器中,未做处理时,滚动到顶部,依然能滚动一段距离。通过下面一些方式,来阻止背景的滚动。
在这里插入图片描述

阻止页面滚动的默认事件

document.addEventListener('touchmove', function(e) {
  e.preventDefault()
}, { passive: false })

页面超出或者含有overflow-y:scroll;的元素时,无法滚动,例如:

<div class="scroll-y">
	<ul>
		<li>456</li>
        <li>456</li>
        <li>456</li>
        <li>456</li>
        <li>456</li>
	</ul>
</div>
.scroll-y {
  width: 100vw;
  height: 200px;
  overflow-x: hidden;
  overflow-y: scroll;
}
ul li {
  margin-bottom: 40px;
}

这时需要捕获滚动事件:

const dom = document.querySelector('.scroll-y')
dom.addEventListener('touchmove', e => {
	e.stopPropagation()
})

页面未设置position时,在IOS端,背景依然是可以滚动的,此时使用position:fixed;使页面固定,可以彻底解决安卓和IOS背景滚动的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值