html 禁止缩放 ios10,完美解决ios10及以上Safari无法禁止缩放的问题

完美解决 ios10 及以上 Safari 无法禁止缩放的问题

转载自掘金-互联网学徒

移动端web缩放有两种:

双击缩放

双指手势缩放

在 iOS 10之前,iOS 和 Android 都可以通过一行 meta 标签来禁止页面缩放:

但 iOS 10开始,meta 设置在 Safari 内无效了。

后来在网上看到一个解决方案:

window.οnlοad=function() {

document.addEventListener('touchstart',function(event) {if(event.touches.length>1){

event.preventDefault();

}

})var lastTouchEnd=0;

document.addEventListener('touchend',function(event) {var now=(newDate()).getTime();if(now-lastTouchEnd<=300){

event.preventDefault();

}

lastTouchEnd=now;

},false)

}

经过测试,这种方法只能禁止双击缩放。只好继续找解决方案了。

6c1555302777729326ca3efa0910d9ec.png

原来在 iOS 里有一组双指手势操作的事件:gesturestart、gesturechange、gestureend

在上面的 js 方法里加入下面的事件监听:

document.addEventListener('gesturestart', function(event) {

event.preventDefault();

});

既不能双击缩放,也不能双指缩放。

完整代码

window.onload = function() {//阻止双击放大

var lastTouchEnd = 0;

document.addEventListener('touchstart', function(event) {if (event.touches.length > 1) {

event.preventDefault();

}

});

document.addEventListener('touchend', function(event) {var now = (newDate()).getTime();if (now - lastTouchEnd <= 300) {

event.preventDefault();

}

lastTouchEnd=now;

},false);//阻止双指放大

document.addEventListener('gesturestart', function(event) {

event.preventDefault();

});

}

这样就OK了,安排!

6c1555302777729326ca3efa0910d9ec.png

来源:https://www.cnblogs.com/mica/p/10848817.html