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

页面放大缩小导致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 }
      )
    }
相关推荐
左夕38 分钟前
分不清apply,bind,call?看这篇文章就够了
前端·javascript
Zha0Zhun1 小时前
一个使用ViewBinding封装的Dialog
前端
兆子龙1 小时前
从微信小程序 data-id 到 React 列表性能优化:少用闭包,多用 data-*
前端
滕青山1 小时前
文本行过滤/筛选 在线工具核心JS实现
前端·javascript·vue.js
时光不负努力1 小时前
编程常用模式集合
前端·javascript·typescript
恋猫de小郭2 小时前
Apple 的 ANE 被挖掘,AI 硬件公开,宣传的 38 TOPS 居然是"数字游戏"?
前端·人工智能·ios
小岛前端2 小时前
Node.js 宣布重大调整,运行十年的规则要改了!
前端·node.js
OpenTiny社区2 小时前
OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用
前端·javascript·ai编程
梦想CAD控件2 小时前
在线CAD开发包结构与功能说明
前端·javascript·vue.js
张拭心2 小时前
春节后,有些公司明确要求 AI 经验了
android·前端·人工智能