tua-body-scroll-lock踩坑记录

在日常工作中,我们经常会遇到拉起弹窗时要禁止页面的滚动,此时tua-body-scroll-lock库就是一个很好的选择。但是最近在维护老项目的时候发现这个项目会监听滚动事件,当滚到到某个地方时就会给标题栏一个底色,如下面代码

javascript 复制代码
      window.addEventListener('scroll', () => {
        if (window.scrollY >= 30) {
          setScroll(1)
        } else {
          setScroll(0)
        }
      }, false)

但是在滑动过程中如果调用lock方法,此时window.scrollY会变为0,会导致标题栏的底色消失,这样的体验很不佳,用户可能会认为有bug。解决方法也很简单,在调用lock时存一个变量,当scroll事件回调发现这个变量为true时也认为此时页面已经滚动了,如下面代码

javascript 复制代码
//调用lock的逻辑
  useEffect(() => {
      if(defaultLock) {
        lock();
        lockRef.current = true;
        window.lock = true;
      }
  }, [])


//监听事件也需要修改下
window.addEventListener('scroll', () => {
  //弹窗打开时会调用lock方法,此时window.scrollY会变为0,所以在弹窗打开时特殊处理下
  if (window.scrollY >= myCoinHeight || window.lock) {
     setMyCoinStatus(1)
   } else {
     setMyCoinStatus(0)
   }
  }, false)

这样处理后就可以避免上面提到的情况了

相关推荐
kk晏然11 小时前
TypeScript 错误类型检查,前端ts错误指南
前端·react native·typescript·react
纆兰11 小时前
汇款单的完成
前端·javascript·html
Lsx_11 小时前
案例+图解带你遨游 Canvas 2D绘图 Fabric.js🔥🔥(5W+字)
前端·javascript·canvas
2501_9445210011 小时前
rn_for_openharmony商城项目app实战-主题设置实现
javascript·数据库·react native·react.js·ecmascript
m0_4711996311 小时前
【场景】如何快速接手一个前端项目
前端·vue.js·react.js
榴莲CC12 小时前
抗干扰LED数显屏驱动VK1624 数码管显示芯片 3线串行接口
前端
lili-felicity12 小时前
React Native for Harmony 个人消息列表最新消息置顶实现(多维度权重统计)
javascript·react native·react.js
Tigger12 小时前
用 Vue 3 做了一套年会抽奖工具,顺便踩了些坑
前端·javascript·vue.js
天天扭码12 小时前
一文搞懂——React 19到底更新了什么
前端·react.js·前端框架
weixin_4624462312 小时前
【原创】使用langchain与MCP 与 Chrome DevTools 打造可调用浏览器工具的 Chat Agent
前端·langchain·chrome devtools