是否可以检测浏览器是否会根据元视口元素缩放网站?
问问题
1184 次
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 回答