Po prostu trzeba uniemożliwić przewijanie na urządzeniu mobilnym za pomocą JS i/lub JQuery po wystąpieniu określonego zdarzenia. Mam figurę, kiedy użytkownik otworzy figurkę, przewijanie zostanie wyłączone, po zamknięciu przewijanie zostanie ponownie włączone. Urządzenia docelowymi są:Zapobieganie przewijaniu na smartfonie dla określonego rozmiaru ekranu
- każdy z iPhone 4s do najnowszej jeden (5 + 6 włączone)
Oto niektóre z rzeczy, które próbowałem, ale nie wyszło:
Method1:
document.addEventListener('touchstart', this.touchstart);
document.addEventListener('touchmove', this.touchmove);
function touchstart(e) {
e.preventDefault()
}
function touchmove(e) {
e.preventDefault()
}
Metoda 2:
// left: 37, up: 38, right: 39, down: 40,
// spacebar: 32, pageup: 33, pagedown: 34, end: 35, home: 36
var keys = {37: 1, 38: 1, 39: 1, 40: 1};
function preventDefault(e) {
e = e || window.event;
if (e.preventDefault)
e.preventDefault();
e.returnValue = false;
}
function preventDefaultForScrollKeys(e) {
if (keys[e.keyCode]) {
preventDefault(e);
return false;
}
}
function disableScroll() {
if (window.addEventListener) // older FF
window.addEventListener('DOMMouseScroll', preventDefault, false);
window.onwheel = preventDefault; // modern standard
window.onmousewheel = document.onmousewheel = preventDefault; // older browsers, IE
window.ontouchmove = preventDefault; // mobile
document.onkeydown = preventDefaultForScrollKeys;
}
function enableScroll() {
if (window.removeEventListener)
window.removeEventListener('DOMMouseScroll', preventDefault, false);
window.onmousewheel = document.onmousewheel = null;
window.onwheel = null;
window.ontouchmove = null;
document.onkeydown = null;
}
Jakieś inne sugestie?
Niestety, to nie działa na urządzeniach, działa dobrze na laptopie tho, takie jak metody, które wyżej wspomniałem. Jakieś inne sugestie? –