Vant Popup 底部弹出层导致页面回滚到顶部问题

看了许多博主的文章,类似于滚动穿透,阻止页面滚动,监听弹窗是否弹出,等各种方案,试用无效后,终于找到了简单又有效地解决方法!!!!!!


我们可以看到popup弹出瞬间,body会短暂性的添加一个类名,弹出后这个类名又会被删除。

所以,只要把这个类名下的效果替换掉就好啦

解决方法:如下↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

.van-overflow-hidden{
    overflow: visible!important;
    overflow-x: visible !important;
    overflow-y: visible !important;
}

but 以上方法仅在pc端有效,移动端写法详见如下 ,仅需在app.vue加上这几段css,亲测有效,项目变的流程无比

app.vue

*{
  padding: 0;
	margin: 0;
	box-sizing: border-box;
}
html,body{
  width: 100%;
  height: 100%;
  overflow: visible;
   -webkit-overflow-scrolling: touch
}
body{
  position: relative;
}

页面部分结构

 <van-field
          readonly
          clickable
          name="customer"
          :value="consultForm.custome"
          label="所在地区"
          placeholder="请选择"
          :is-link="true"
          arrow-direction="down"
          @click="showArea = true"
          :rules="[{ required: true, message: '' }]"
        />
          <van-popup v-model="showArea" position="bottom">
            <van-area
              :area-list="areaList"
              @confirm="onAddConfirm"
              @cancel="showArea = false"
            />
          </van-popup>
         

效果图:,弹出层弹出时,底部不再滑动

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值