1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 【微信小程序】小程序显示弹窗时禁止下层的内容滚动|遮罩层滚动穿透

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

时间:2021-07-08 22:06:03

相关推荐

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

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

第一种方式

页面上加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})}})

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。