美文网首页
【Flutter Web】在iOS的Safari浏览器,左边侧滑

【Flutter Web】在iOS的Safari浏览器,左边侧滑

作者: Wing_Li | 来源:发表于2024-02-04 11:25 被阅读0次

    如下图:


    开始还以为是 Flutter 返回的问题,使用 WillPopScope 禁用返回,没有效果。

    侧滑的问题只有 Safari 浏览器有问题。
    最后发现不是 Flutter 层面的问题,侧滑返回是Safari浏览器的功能。
    目前能找到的解决方案是在 index.html 层面做一些操作,将最左边的一小部分区域禁用,这样用户滑动就无效了。
    但是也无法彻底避免,有时候还是能滑出来,但也勉强好一些。

    我使用下面的代码,实测有效 (将下面代码放在 项目/web/index.html 的 <script></script> 标签里面):

    function handleTouchMove(event, xStart, yStart) {
      var xDiff = xStart - event.touches[0].pageX;
      var yDiff = yStart - event.touches[0].pageY;
    
      // Prevent horizontal swipe
      if (xDiff > 20 && Math.abs(xDiff) > Math.abs(yDiff)) {
        event.preventDefault();
      }
    }
    
    var newHandleTouchMove = function (xStart, yStart) {
      return function (event) {
        handleTouchMove(event, xStart, yStart);
      };
    }
    
    document.addEventListener('touchstart', function (startEvent) {
      // Ignore multi-touch gestures
      if (startEvent.touches.length > 1) {
        return;
      }
    
      var xStart = startEvent.touches[0].pageX;
      var yStart = startEvent.touches[0].pageY;
    
      // Attach the touchmove event listener
      document.addEventListener('touchmove', newHandleTouchMove(xStart, yStart), { passive: false });
    }, { passive: false });
    

    当网页彻底加载完成之后,最左侧滑动就不会有反应了。


    关联链接:
    https://github.com/flutter/flutter/issues/114324
    https://github.com/flutter/gallery/issues/898
    https://github.com/flutter/flutter/issues/76478

    相关文章

      网友评论

          本文标题:【Flutter Web】在iOS的Safari浏览器,左边侧滑

          本文链接:https://www.haomeiwen.com/subject/krdfadtx.html