3

是否可以检测浏览器是否会根据元视口元素缩放网站?

4

2 回答 2

1

没有任何 JavaScript 方法可以检测是否将应用元视口。但是,您可以检查它是否是通过两步过程在头部使用内联 js 应用的,方法如下:

<head>
<script>
  var clientWidth = document.documentElement.clientWidth;
</script>
<meta name="viewport" content="width=device-width,initial-scale=1">
<script>
  if (clientWidth !== document.documentElement.clientWidth){
  //device or browser support the meta-viewport which just changed the width
  }
</script>
</head>

这在移动设备上最常见的情况下适用于响应式设计,因为移动设备的初始/默认视口是 980 像素(http://www.quirksmode.org/mobile/metaviewport/),这根本不是常见的桌面屏幕. 并且当前没有桌面浏览器支持元视口。

我将使用此方法作为在这方面检测移动设备的因素。但是,值得注意的是,也有例外。因此,您不能仅对所有设备都依赖上述方法。

例如,对于 Blackberry Playbook,默认视口大小已经匹配 600x1024 像素大小device-width, initial-scale=1,因此尽管元视口重新缩放,clientWidth 也不会改变。

于 2014-05-17T07:35:17.230 回答
0

不,元视口元素只是告诉移动浏览器它应该如何处理当前页面。所以,这取决于你会做什么。

如果您将捕获调整大小事件,那么您可以使用一些 javascript 来完成:

$(window).resize(function() {
    //resize just happened, pixels changed
});

或者,如果您只想在不同的屏幕尺寸上添加不同的样式,请在您的 css 文件中使用媒体查询,例如:

@media only screen and (min-width : 30em) {
    body{font-size: 125%;}
}

@media only screen and (min-width: 37.5em) {
    body{font-size: 163%;}
} 
于 2013-06-04T14:26:57.137 回答