【解决】vue 弹窗后面页面可以滚动问题

做web端项目过程中,发现点击弹窗后,弹窗后面的页面还可以滚动。

复现如下:

【方法1】

step1:在弹框页面使用

javascript 复制代码
@mousewheel.prevent
javascript 复制代码
<div
    v-show="workShowMenu"
    @mousewheel.prevent
 >
 // TO DO...弹框内容
</div>

注意:该方法不适用于弹框上也有滚动条的时候,会失效。

方法2】

step1:在点击出现弹框的事件里加上这句:

javascript 复制代码
document.documentElement.style.overflow = "hidden";

step2:在点击关闭弹框的事件里加上这句:

javascript 复制代码
document.documentElement.style.overflow = "scroll";

【优化】

若项目里使用弹窗较多,则可以通过在原型上定义它们使其在每个 Vue 的实例中可用(main.js)

javascript 复制代码
//弹出框后面页面禁止滑动
Vue.prototype.$stopScroll = function () {
  document.documentElement.style.overflow = "hidden";
}

//弹出框后面页面可以滑动
Vue.prototype.$allowScroll = function () {
   document.documentElement.style.overflow = "scroll";
}

step1:在点击出现弹框的事件里加上这句:

javascript 复制代码
this.$stopScroll();

step2:在点击关闭弹框的事件里加上这句:

javascript 复制代码
this.$allowScroll();

注:两个事件之所以要用开头,因为 是在 Vue所有实例中都可用的属性的一个简单约定。这样做会避免和已被定义的数据、方法、计算属性产生冲突。

相关推荐
我是伪码农5 小时前
Vue 1.23
前端·javascript·vue.js
wqwqweee5 小时前
Flutter for OpenHarmony 看书管理记录App实战:搜索功能实现
开发语言·javascript·python·flutter·harmonyos
HIT_Weston7 小时前
107、【Ubuntu】【Hugo】搭建私人博客:模糊搜索 Fuse.js(三)
linux·javascript·ubuntu
henujolly10 小时前
ethers.js读取合约信息
开发语言·javascript·区块链
毕设源码-郭学长10 小时前
【开题答辩全过程】以 基于Web的高校课程目标达成度系统设计与实现为例,包含答辩的问题和答案
前端
wuhen_n10 小时前
高阶函数与泛型函数的类型体操
前端·javascript·typescript
POLITE311 小时前
Leetcode 437. 路径总和 III (Day 16)JavaScript
javascript·算法·leetcode
難釋懷11 小时前
解决状态登录刷新问题
java·开发语言·javascript
ヤ鬧鬧o.11 小时前
多彩背景切换演示
前端·css·html·html5
一起养小猫12 小时前
Flutter实战:从零实现俄罗斯方块(三)交互控制与事件处理
javascript·flutter·交互