解决ios10及以上Safari双击和双指缩放无法禁止的问题
Posted catherlee
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> /*禁止ios缩放,双击和双指*/ 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>
参考链接:
https://stackoverflow.com/questions/37808180/disable-viewport-zooming-ios-10-safari
以上是关于解决ios10及以上Safari双击和双指缩放无法禁止的问题的主要内容,如果未能解决你的问题,请参考以下文章
iPhone 和 iPad 上的 Safari 在缩放时崩溃(双击和捏合)