自定义指令--【v-lockScroll】用来锁定滚动条

背景

最近在开发业务上,遇到了自己封装的modal组件,组件弹出的时候,会覆盖到页面最上层。 但是覆盖出现了,而页面底层的滚动条还可以滑动,这样对用户就不是很友好了。 如下效果:

解决方案

于是,思考过后,发现我们自己封装一个自定义指令,在组件展示的时候将滚动条给锁定+隐藏,问题就解决了。

思路

  • 当我们使用v-lockscroll="true"时,在指令mounted时计算出滚动条的宽度

    滚动条的宽度=浏览器窗口宽度 - 文档内部宽度.

  • body设置overflow为hidden

  • 重新设置body宽度和浏览器窗口宽度一致。

  • unmounted时候将body的overflow和宽度复原到最初。

具体的实现如下:

vue 复制代码
<template>
    <!-- 使用自定义指令 -->
    <div v-lockscroll>
        //....其余DOM元素
    </div>
</template>


<script setup>
//自定义指令锁定滚动条
const VLockscroll = {
    mounted(_el, binding) {
        if (binding.value) {
            const scrollBarWidth = window.innerWidth - document.documentElement.clientWidth
            document.body.style.overflow = 'hidden'
            document.body.style.width = `calc(100% - ${scrollBarWidth}px)`
            // console.log('scrollBarWidth', scrollBarWidth);
            // document.body.style.paddingRight = `${scrollBarWidth}px`
        }
    },
    unmounted() {
        document.body.style.overflow = ''
        document.body.style.width = ''
    }
}
</script>

效果

这个时候当我们再次打开组件时候,页面的滚动条就被禁用了。


朋友,我是喝西瓜汁的兔叽,感谢您的阅读,衷心祝福您和家人身体健康,事事顺心。

相关推荐
骑着小黑马3 分钟前
Electron + Vue3 + AI 做了一个新闻生成器:从 0 到 1 的完整实战记录
前端·人工智能
Sailing5 分钟前
LLM 调用从 60s 卡死降到 3s!彻底绕过 tiktoken 网络阻塞(LangChain.js 必看)
前端·langchain·llm
洋洋技术笔记5 分钟前
计算属性与侦听器
前端·vue.js
用户814486958115 分钟前
“马上”有惊喜:在 Rokid 灵珠平台上构建 FPS 级 AR 红包雷达应用
前端
李剑一12 分钟前
拿来就用!Vue3+Cesium 飞入效果封装,3D大屏多场景直接复用
前端·vue.js·cesium
天蓝色的鱼鱼40 分钟前
都2026年了还不会Vite插件开发?手写一个版本管理插件,5分钟包会!
前端·vite
苏武难飞1 小时前
分享一个33号远征队的效果!
前端
鹏程十八少1 小时前
4.Android 30分钟手写一个简单版shadow, 从零理解shadow插件化零反射插件化原理
android·前端·面试
亿元程序员1 小时前
这款值68亿的游戏,你不实战一下吗?安排!
前端
摸鱼的春哥2 小时前
Agent教程15:认识LangChain(中),状态机思维
前端·javascript·后端