欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-12-06 15:15:52
小程序显示弹窗时禁止下层的内容滚动实现方法,具体如下 ①  第一种方式 利用position:fixed.  禁止页面滚动. 一. 页面结...

小程序显示弹窗时禁止下层的内容滚动实现方法,具体如下

①  第一种方式

利用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>

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。