【Flutter Web】在iOS的Safari浏览器,左边侧滑将页面划为空了

如下图:


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

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

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

javascript 复制代码
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 });

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


关联链接: github.com/flutter/flu... github.com/flutter/gal... github.com/flutter/flu...

相关推荐
多看书少吃饭4 分钟前
从 ScriptProcessor 到 AudioWorklet:Electron 桌面端录音实践总结
前端·javascript·electron
user71422659645789 分钟前
react中useMemo和useCallback的使用场景
前端
JS_GGbond12 分钟前
前端水印实战:给你的页面穿上“隐形盔甲”
前端
Sthenia16 分钟前
如何用 Chrome DevTools 定位 Long Task:一份从零到实战的排查笔记
前端·性能优化
用户222645989434128 分钟前
CSS单位全解析:从像素到视口的响应式设计
前端
Mapmost29 分钟前
【实景三维】还再为渲染发愁?手把手教你大场景如何实现“精细”与“流畅”平衡!
前端
钱多多81030 分钟前
Vue版本降级操作指南(解决依赖冲突与版本不一致问题)
前端·javascript·vue.js·前端框架
San3033 分钟前
深度解析 React 组件化开发:从 Props 通信到样式管理的进阶指南
前端·javascript·react.js
AAA阿giao33 分钟前
深度解析 React 项目架构:从文件结构到核心 API 的全面拆解
前端·javascript·react.js
LYFlied40 分钟前
Vue3虚拟DOM更新机制源码深度解析
前端·算法·面试·vue·源码解读