固定宽度导致手机页面挤成一团,因像素值如1200px远超手机375–414px屏幕,浏览器只能缩放或横向滚动;须改用相对单位、补全viewport标签、移动优先写媒体查询、约束图片iframe、保障点击区域≥44px。
因为写死了 width: 1200px 或 max-width: 1200px,而手机屏幕只有 375–414px 宽,浏览器只能强行缩小整个布局或横向滚动。这不是“变形”,是 CSS 拒绝适配的明确信号。
width、height、padding、margin,尤其是容器类(如 .container、.wrapper)width: 100%、max-width: 100%、pa
dding: 1rem(而非 padding: 16px)zoom、transform: scale() 等视觉缩放手段——它们不改变布局流,只会让元素“糊”在一起没有它,移动端浏览器会按桌面宽度(通常是 980px)渲染页面,再缩放显示,导致文字小得看不清、点击区域错位。这是响应式起步就该确认的第一步。
内,且不能被 JS 动态插入(部分安卓 WebView 不识别)user-scalable=no——它会锁死缩放,对视障用户不友好,也违反 WCAG 基本要求initial-scale=1.0 但页面仍偏大/偏小,检查是否有其他 meta 标签重复声明 viewport等页面写完再加 @media (max-width: 768px) 往往要推翻大量样式。真正有效的做法是:移动优先,先写小屏基础样式,再用 min-width 逐步增强。
@media (min-width: 768px) {
.header-nav {
display: flex;
}
.header-logo {
font-size: 1.5rem;
}
}
@media (min-width: 1024px) {
.container {
max-width: 1200px;
}
}
display: block,大屏又写 display: flex ——没问题;但若小屏没设 font-size,大屏却写 font-size: 1.2rem,小屏就会继承浏览器默认值,可能突兀)!important 在媒体查询中覆盖——它会让后续调试变成猜谜就算 .content 设置了 width: 100%,里面的 或嵌入的 YouTube 视频仍可能溢出,因为它们默认按原始尺寸渲染。
img { max-width: 100%; height: auto; }
aspect-ratio(Chrome 103+、Firefox 110+ 支持)background-image,记得配 background-size: cover 或 contain,否则会拉伸或裁切font-size: 16px 在手机上看着还行,但手指点击 16px 高的按钮,误触率极高。至少保证可点击元素的 min-height 和 padding 合计 ≥ 44px。
来电咨询