移动端禁用双击放大手势

网上容易找到的方法之一就是在head标签内定义页面元信息(meta)viewport如下:

 
 
COPY
EXPAND
1
<meta name="viewportcontent="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0">
 
 
COPY
EXPAND

尝试后发现并不怎么靠谱,并没有达到预期的效果,部分浏览器仍然会响应双击放大的手势。最终解决方案如下:

 
 
COPY
EXPAND
1
2
3
4
5
6
7
<script>
    // “一刀切”方案:
    document.ontouchend = function (e) {
        // 阻止页面 touchend 的默认事件
        e.preventDefault();
    }
</script>
 
 
COPY
EXPAND

当然这个办法并不理智,这样做会导致页面的click事件在移动端上失效,补救的办法可以是使用ontouchstart来代替click

建议

其实完全可以通过避免页面内元素超出设备宽度来避免浏览器双击放大手势事件,不到万不得已最好还是在页面CSS上“下功夫”,合理进行页面布局和响应式才是正道。

转载于:https://www.cnblogs.com/Orcim/p/11431641.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值