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

移动端web缩放有两种:web

1.双击缩放;bash

2.双指手势缩放。移动端web

在iOS 10之前,iOS和Android均可以经过一行meta标签来禁止页面缩放测试

<meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0;" name="viewport" />spa

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

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

window.onload=function () {
    document.addEventListener('touchstart',function (event) {
        if(event.touches.length>1){
            event.preventDefault();
        }
    })
    var lastTouchEnd=0;
    document.addEventListener('touchend',function (event) {
        var now=(new Date()).getTime();
        if(now-lastTouchEnd<=300){
            event.preventDefault();
        }
        lastTouchEnd=now;
    },false)
}
复制代码

通过测试,这种方法只能禁止双击缩放。code

只好继续找解决方案了。cdn

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

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

document.addEventListener('gesturestart', function (event) {
      event.preventDefault();
    });
        
复制代码

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

完整代码:

<script>
      window.onload=function () {
        document.addEventListener('touchstart',function (event) {
          if(event.touches.length>1){
            event.preventDefault();
          }
        });
        var lastTouchEnd=0;
        document.addEventListener('touchend',function (event) {
          var now=(new Date()).getTime();
          if(now-lastTouchEnd<=300){
            event.preventDefault();
          }
          lastTouchEnd=now;
        },false);
        document.addEventListener('gesturestart', function (event) {
          event.preventDefault();
        });
      }
    </script>
复制代码

这样就OK了,安排!

相关文章
相关标签/搜索