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

相关推荐
狗哥哥17 小时前
Pinia Store 平滑迁移:用代理模式实现零风险重构
前端·架构
老前端的功夫17 小时前
前端水印技术深度解析:从基础实现到防破解方案
开发语言·前端·javascript·前端框架
霍格沃兹测试学院-小舟畅学17 小时前
性能测试入门:使用 Playwright 测量关键 Web 性能指标
开发语言·前端·php
tangbin58308517 小时前
iOS Swift 工具类:数据转换工具 ParseDataTool
前端
潜水豆17 小时前
AI 时代的前端究竟还能积累什么
前端
www_stdio17 小时前
手写 instanceof:深入理解 JavaScript 原型与继承机制
前端·javascript·html
boombb17 小时前
国际化方案:多环境、多语言、动态加载的完整实践
前端
狗哥哥17 小时前
我是如何治理一个混乱的 Pinia 状态管理系统的
前端·vue.js·架构
一 乐17 小时前
物业管理|基于SprinBoot+vue的智慧物业管理系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot
测试人社区—527217 小时前
你的单元测试真的“单元”吗?
前端·人工智能·git·测试工具·单元测试·自动化·log4j