网站页面放大缩小带来的问题

页面放大缩小导致v-infinite-scroll失效

  • v-infinite-scroll 通常通过比较 scrollTop + clientHeightscrollHeight 来判断是否接近底部。页面放大后,这些 DOM 属性的值可能因缩放而产生计算偏差,导致条件永远不满足。
  • infinite-scroll-distance的默认值是0,而页面ctrl+滚轮放缩后,上面的运算的差永远不是0,导致无法触发scrollToBottom事件,把值改成20即可
js 复制代码
  <div class="scroll-container"
       v-infinite-scroll="scrollToBottom"
       infinite-scroll-distance="20">
  </div>
  
      async scrollToBottom() {
      // 虽然可以通过增加属性 infinite-scroll-disabled 来禁用,在js里通过这样直接禁用也省事
      if (this.inLoading || this.finished) return
      this.getListParams.pageIndex++
      const appendList = await this.getList()
      this.list = [...this.list, ...appendList]
    },

页面禁止放大缩小

js 复制代码
    forbiddenZoomChange() {
      // 禁止ctrl+ +/- 缩放
      document.addEventListener(
        'keydown',
        function (event) {
          if (
            (event.ctrlKey === true || event.metaKey === true) &&
            (event.keyCode === 61 ||
              event.keyCode === 107 ||
              event.keyCode === 173 ||
              event.keyCode === 109 ||
              event.keyCode === 187 ||
              event.keyCode === 189)
          ) {
            event.preventDefault()
          }
        },
        false
      )
      // 禁止ctrl+滚轮 缩放
      document.addEventListener(
        'mousewheel',
        function (e) {
          e = e || window.event
          if ((e.wheelDelta && event.ctrlKey) || e.detail) {
            event.preventDefault()
          }
        },
        { passive: false }
      )
      // 禁止触摸缩放
      document.documentElement.addEventListener(
        'touchstart',
        function (event) {
          if (event.touches.length > 1) {
            event.preventDefault()
          }
        },
        { passive: false }
      )
      // 禁止双击放大
      let lastTouchEnd = 0
      document.documentElement.addEventListener(
        'touchend',
        function (event) {
          var now = Date.now()
          if (now - lastTouchEnd <= 300) {
            event.preventDefault()
          }
          lastTouchEnd = now
        },
        { passive: false }
      )
    }
相关推荐
chxii9 小时前
在 IIS 中实现 SSL 证书的自动续期
前端
周星星日记9 小时前
vue3中静态提升和patchflag实现
前端·vue.js·面试
橘子编程9 小时前
React 19 全栈开发实战指南
前端·react.js·前端框架
DanCheOo9 小时前
AI Streaming 架构:从浏览器到服务端的全链路流式设计
前端·agent
我是小趴菜9 小时前
前端如何让图片、视频、pdf等文件在浏览器直接下载而非预览
前端
cg3310 小时前
开源项目自动化:用 GitHub Actions 让每个 Issue 都被温柔以待
前端
haierccc10 小时前
Win7、2008R2、Win10、Win11使用FLASH的方法
前端·javascript·html
We་ct10 小时前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
柠檬味的Cat10 小时前
使用腾讯云COS作为WordPress图床的实践
前端·github·腾讯云
Hilaku10 小时前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试