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

Posted ~逍遥★星辰~

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了完美解决ios10及以上Safari无法禁止缩放的问题相关的知识,希望对你有一定的参考价值。

移动端web缩放有两种:

1.双击缩放;

2.双指手势缩放。

ios 10以前,iOS和android都可以通过一行meta标签来禁止页面缩放

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

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

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

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)
}

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

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

在上面的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了

以上是关于完美解决ios10及以上Safari无法禁止缩放的问题的主要内容,如果未能解决你的问题,请参考以下文章

想请问,iOS10网页viewport怎么禁止缩放

iOS Mobile Safari 纵向布局过于缩放

ios 双击页面缩放 禁止

解决ios10以上版本缩放问题

解决IOS下meta设置user-scalable=no无效

iPad (iOS6) 上的 Safari 无法缩放 HTML5 视频以填充 100% 的页面宽度