zoukankan      html  css  js  c++  java
  • 完美解决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了

  • 相关阅读:
    设计模式_抽象工厂模式
    KMeans聚类算法Hadoop实现
    JDK核心JAVA源代码解析(1)
    pushlet单播与多播
    SQL 2008 R2数据库变为REPLICATION,日志不断增长并且不能截断和收缩的解决方式
    chrome插件的popup与跨域请求
    Ubuntu vim+ ctags(包括系统函数) + taglist 配置
    spring Valid @Pattern 常见的验证表达式
    spring boot 全局异常处理
    spring 事件使用
  • 原文地址:https://www.cnblogs.com/xiaoyaoxingchen/p/10519513.html
Copyright © 2011-2022 走看看