【微信小程序】小程序显示弹窗时禁止下层的内容滚动|遮罩层滚动穿透

小程序显示弹窗时禁止下层的内容滚动|遮罩层滚动穿透

第一种方式
页面上加catchtouchmove="consume"
JS

//  把这个事件给消耗掉,这是是必须写的, 不写是可以实现但是控制台会弹警告
consume() {
      return false
    }

你在开发者工具上用鼠标滑轮,下面的内容它是可以滑动的。手机上展示就可以阻止了(为什么?因为:touchmove是手指触摸后移动的事件,小程序是在手机上展示的没有鼠标,你可以在开发者工具上按住左键拖动鼠标来测试)

//此处为弹窗内容
<view catchtouchmove="consume"> //把手指触摸后移动的事件消耗掉
  <view> // 有需要滚动的列表区域位置不要加 catchtouchmove="consume", 否则列表无法滚动
    <view>滚动列表1</view>
    <view>滚动列表2</view>
    <view>滚动列表3</view>
    <view>滚动列表4</view>
  </view>
</view>

第二种方式
利用position:fixed; 禁止页面滚动

一. 页面结构html

<view class="indexPage {{proInfoWindow?'indexFixed':''}}">
  -----------此处为整个页面的结构内容
  <button catchTap="_proInfoWindowShow">点击显示弹窗</button>
</view>
// 当proInfoWindow为true的时候显示弹窗
<view wx:if="{{proInfoWindow}}">此处为弹窗内容</view>

二. CSS部分

//添加一个类名, 把弹窗的下层内容定位为fixed.实现禁止滚动的效果
.indexFixed{
 position: fixed;
 top:0;//top:0可不写,否则显示弹窗的同时会使底层滚动到顶部.
 left:0;
 bottom:0;
 right:0;
}

三. JS部分

Page({
 data: { 
  proInfoWindow:false,//控制弹窗是否显示
    
 },
  // 点击弹窗事件, 设置proInfoWindow为true, 显示弹窗.
  // 设置proInfoWindow为true的同时, 给页面添加了一个class名为indexFixed的类.显示弹窗时下层就禁止滚动,关掉弹窗时就可以滚动.
 _proInfoWindowShow(){
   this.setData({
    proInfoWindow:true
  })
 }
})
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值