【技术支持】关于html中移动端innerwidth的问题

首先看问题

移动端web相关

屏幕是375*667

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <!-- <meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=0" /> -->
        <meta name="viewport" content="width=device-width, initial-scale=2.0" />
        <title>Document</title>
        <style>
            * {
                margin: 0;
            }
            #test {
                height: 100px;
                background-color: aquamarine;
            }
        </style>
    </head>
    <body>
        <div id="test"></div>
        <script>
            let div = document.getElementById("test");
            console.log(window.innerWidth); //375
            console.log(document.documentElement.clientWidth); //375
            div.style.width = 970 + "px";
            console.log(window.innerWidth); //971
            console.log(document.documentElement.clientWidth); //375
        </script>
    </body>
</html>

此代码在桌面端正常,在移动端有些异常,移动端的window.innerWidth不是视口大小,会变化

解决办法就是<meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=0" />,添加user-scalable=0

相关推荐
蒙特卡洛的随机游走几秒前
Spark的宽依赖与窄依赖
大数据·前端·spark
共享家95278 分钟前
QT-常用控件(多元素控件)
开发语言·前端·qt
幸运小圣8 分钟前
Iterator迭代器 【ES6】
开发语言·javascript·es6
葱头的故事9 分钟前
将传给后端的数据转换为以formData的类型传递
开发语言·前端·javascript
中微子20 分钟前
🚀 2025前端面试必考:手把手教你搞定自定义右键菜单,告别复制失败的尴尬
javascript·面试
_233321 分钟前
vue3二次封装element-plus表格,slot透传,动态slot。
前端·vue.js
jump68024 分钟前
js中数组详解
前端·面试
崽崽长肉肉27 分钟前
iOS 基于Vision.framework从图片中提取文字
前端
温宇飞33 分钟前
Web Abort API - AbortSignal 与 AbortController
前端
Tomoon34 分钟前
前端开发者的全栈逆袭
前端