【Flutter Web】在iOS的Safari浏览器,左边侧滑将页面划为空了
如下图:
开始还以为是 Flutter 返回的问题,使用 WillPopScope 禁用返回,没有效果。
侧滑的问题只有 Safari 浏览器有问题。
最后发现不是 Flutter 层面的问题,侧滑返回是Safari浏览器的功能。
目前能找到的解决方案是在 index.html 层面做一些操作,将最左边的一小部分区域禁用,这样用户滑动就无效了。
但是也无法彻底避免,有时候还是能滑出来,但也勉强好一些。
我使用下面的代码,实测有效 (将下面代码放在 项目/web/index.html 的 标签里面):
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
- 感谢你赐予我前进的力量
赞赏者名单
因为你们的支持让我意识到写文章的价值🙏
本文是原创文章,采用 CC BY-NC-ND 4.0 协议,完整转载请注明来自 时光·李记
评论
匿名评论
隐私政策
你无需删除空行,直接评论以获取最佳展示效果