作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在 SPA 上完全禁用向后滑动动画。这将允许我在 SPA 中使用一些滑动手势。目前在 iOS 上,当触发某些手势时,您往往也会触发向后滑动手势。
我找到了关于如何禁用它的上一篇文章:iOS 7 - is there a way to disable the swipe back and forward functionality in Safari?
他们建议如下:
1) CSS 仅修复 Chrome/Firefox
html, body {
overscroll-behavior-x: none;
}
if (window.safari) {
history.pushState(null, null, location.href);
window.onpopstate = function(event) {
history.go(1);
};
}
最佳答案
在 iOS 13.4+ 中,您现在可以 preventDefault()
在 "touchstart"
start 事件以停止导航操作。
假设我们有一个 <div class="block-swipe-nav">
在跨越视口(viewport)整个宽度的页面上,我们希望防止在该元素上滑动导航。
const element = document.querySelector('.block-swipe-nav');
element.addEventListener('touchstart', (e) => {
// is not near edge of view, exit
if (e.pageX > 10 && e.pageX < window.innerWidth - 10) return;
// prevent swipe to navigate gesture
e.preventDefault();
});
关于javascript - 有没有办法在 iOS 上的 Safari 中禁用向后滑动动画?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55574478/
我是一名优秀的程序员,十分优秀!