【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...

相关推荐
Yiyaoshujuku1 分钟前
化学谱图数据API接口,数据字段一览!
linux·服务器·前端
雮尘32 分钟前
LangGraph 与 LangSmith 入门教程(JS/TS 版)
前端·人工智能·langchain
英勇无比的消炎药33 分钟前
新手必看玩转TinyRobot一定要避开这些坑
前端·vue.js
持敬chijing38 分钟前
Web渗透之前后端漏洞-文件上传漏洞-过滤绕过与配置文件漏洞-条件竞争漏洞
前端·安全·web安全·网络安全·网络攻击模型·安全威胁分析
尼斯湖皮皮怪42 分钟前
iceCoder:验收门控深度分析
前端·agent
周庆猛1 小时前
Babylon.js 多灯场景在 Windows 上报错:VERTEX shader uniform block count exceeds GL_MAX_VE
前端·数据可视化
胡志辉1 小时前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·面试
槑有老呆1 小时前
用 Bun 写一个 RESTful TodoList,顺便把面向接口编程整明白
前端
英勇无比的消炎药1 小时前
别再盲目混用AI组件库和传统组件库差距原来这么大
前端·vue.js
ViavaCos1 小时前
AI 帮我写代码,我帮 AI 踩坑:Vue 大数据表格优化全记录
前端·性能优化