vue 进入首页只弹一个弹框_完美解决vue项目中弹出框滑动时,内部页面也跟着滑动问题...

在Vue项目中,解决弹出框出现时导致内部页面跟随滑动的问题。通过在main.js中设置全局函数`noScroll`和`canScroll`来禁止和允许页面滑动。同时针对安卓设备的兼容性问题,引入ModalHelper方法,用于在弹框打开和关闭时处理页面滚动状态。通过调用`ModalHelper.afterOpen()`和`ModalHelper.beforeClose()`来控制滚动行为。
摘要由CSDN通过智能技术生成

在main.js中设置全局函数:

//弹出框禁止滑动

Vue.prototype.noScroll = function () {

var mo = function (e) { e.preventDefault() }

document.body.style.overflow = 'hidden'

document.addEventListener('touchmove', mo, false)// 禁止页面滑动

}

//弹出框可以滑动

Vue.prototype.canScroll = function () {

var mo = function (e) {

e.preventDefault()

}

document.body.style.overflow = ''// 出现滚动条

document.removeEventListener('touchmove', mo, false)

}

在页面使用时:

//禁止主页面滑动

this.noScroll()

//主页面可滑动

this.canScroll()

因为当初是在苹果手机上的测试的,但是在安卓手机发现有些限制,于是解决办法为在main.js中设置全局函数:

// 弹出框显示后调用afterOpen,关闭弹出框前调用beforeClose

Vue.prototype.ModalHelper = (function (bodyCls) {

var scrollTop

return {

afterOpen: function () {

scrollTop = document.scrollingElement.scrollTop

document.body.classList.add(bodyCls)

document.body.style.top = -scrollTop + 'px'

},

beforeClose: function () {

document.body.classList.remove(bodyCls)

// scrollTop lost after set position:fixed, restore it back.

document.scrollingElement.scrollTop = scrollTop

}

}

}('dialog-open'))

在需要的地方调用:

打开滑动: this.ModalHelper.beforeClose();

关闭滑动: this.ModalHelper.afterOpen()

本文地址:https://blog.csdn.net/hahahhahahahha123456/article/details/107864001

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值