移动端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了,安排!