小程序显示弹窗时禁止下层的内容滚动

45次阅读

共计 957 个字符,预计需要花费 3 分钟才能阅读完成。

小程序显示弹窗时禁止下层的内容滚动
小程序显示弹窗时禁止下层的内容滚动
① 第一种方式利用 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
})
}})
②第二种方式
用 catchtouchmove=”return”

// 此处为弹窗内容 <view catchtouchmove=”return”> // 外层加 catchtouchmove=”return” 仅触摸背景区域时不穿透底部.
<view catchtouchmove=”return”></view> // 在每个小的区域内加 catchtouchmove=”return”
<view> // 有需要滚动的列表区域位置不要加 catchtouchmove=”return”, 否则列表无法滚动
<view> 滚动列表 1 </view>
<view> 滚动列表 2 </view>
<view> 滚动列表 3 </view>
<view> 滚动列表 4 </view>
</view>
</view>

正文完
 0