这三种方法我都试过了,但都无济于事:

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

<meta name=”viewport” content=”width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=false;” />

<meta name=”viewport” content=”width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=no;” />

每个是不同的值,我发现谷歌搜索或SO搜索推荐,但没有一个'user-scalable=X'值似乎是工作的

我还尝试用逗号来分隔值,而不是分号,运气不好。然后我尝试只呈现用户可扩展的价值,但仍然没有成功。


更新

从苹果的网站上得到了这个,它是有效的:

<meta name="viewport" content="width=device-width, user-scalable=no" />

事实证明,问题是不标准的引号,因为我从一个网站复制了元标签,正在使用他们,哎呀


当前回答

对于寻找iOS 10解决方案的人来说,在iOS 10的Safari中,user-scaleable=no是禁用的。原因是苹果正试图通过允许人们放大网页来提高可访问性。

来自发行说明:

为了提高Safari网站的可访问性,用户现在可以 中设置了user-scalable=no时,也可以缩放 视窗。

所以据我所知,我们运气不好。

其他回答

在Safari 9.0及以上版本中,您可以在视口元标签中使用如下所示的“缩小到适合”

<meta name="viewport" content="width=device-width, initial-scale=1.0, shrink-to-fit=no">

对于寻找iOS 10解决方案的人来说,在iOS 10的Safari中,user-scaleable=no是禁用的。原因是苹果正试图通过允许人们放大网页来提高可访问性。

来自发行说明:

为了提高Safari网站的可访问性,用户现在可以 中设置了user-scalable=no时,也可以缩放 视窗。

所以据我所知,我们运气不好。

截至今天(2022年10月),在iOS 14.8上,我可以完全防止双击缩放的唯一方法是:

document.addEventListener("click", (e) =>
        {
            e.preventDefault();
        })

即使是这样的:

* {
    touch-action: none !important;
}

(这显然是不现实的,但只是为了演示目的)在每种情况下都是不够的。事实证明,任何我处理过的for元素点击,双击它将导致几乎不可逆的放大,完全忽略触摸操作设置。但是如果我在点击处理程序中调用preventDefault(),它就不会缩放。因此,到目前为止,在文档级别上这样做似乎就足够了,这样我就不必每次处理单击时都这样做。

我不知道这可能会有什么副作用,但我相信如果人们想到了什么,他们会插话的。

我在iOS 12中使用以下代码:

if (/iPad|iPhone|iPod/.test(navigator.userAgent)) {
  window.document.addEventListener('touchmove', e => {
    if(e.scale !== 1) {
      e.preventDefault();
    }
  }, {passive: false});
}

使用第一个if语句,我确保它只会在iOS环境中执行(如果它在Android中执行,滚动行为将被破坏)。另外,请注意被动式选项设置为false。

有时候内容标签中的其他指令会打乱苹果关于如何布局页面的最佳猜测/启发式,你只需要禁用缩放。

<meta name="viewport" content="user-scalable=no" />