viewport 兼容性问题

发布于 2022-08-26 18:41:34 字数 926 浏览 38 评论 0

Hi all,

最近在开发一个mobile网站,在使用viewport的时候遇到了一些问题.

多番尝试之后,现在的情况是UC, Chrome, Android自带的browser, safari都可以如愿按缩放比显示.

但是在用户量巨大的QQ浏览器中,发现似乎不能识别(或者说不能使用)viewport.

代码如下:

HTML

<meta id="viewport" content="
    target-densitydpi=device-dpi, 
    user-scalable=no, 
    width=device-width, 
    initial-scale=0.5" name="viewport" />

JavaScript

var viewPortScale;
var dpr = window.devicePixelRatio;
if(dpr <= 2) {
    viewPortScale = 1 / window.devicePixelRatio;
} else {
    viewPortScale = 0.5
}

document.getElementById('viewport').setAttribute(
        'content', 
        'user-scalable=no, 
         width=device-width, 
        initial-scale=' + viewPortScale);

// alert(viewPortScale);

如果去掉alert的注释,QQ浏览器会弹出显示所需要的缩放比,但是仍然没有按照需求缩放。

不知道针对这种情况如何解决QQ浏览器的兼容性问题?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

痴梦一场 2022-09-02 18:41:34

target-densitydpi=device-dpi 是以屏幕分辨率进行渲染,最新webkit内核已不支持该写法,可以用 width=1080代替,但这种写法也有好多坑。所以最推荐的写法应该是width=device-width,也就是以设备分辨率进行渲染,目前主流都是这种写法,但这样一来页面就没那么精致了。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文