0

0

CSS网格实现全屏布局_vh单位与Grid的完美结合案例

P粉602998670

P粉602998670

发布时间:2026-02-23 12:52:03

|

768人浏览过

|

来源于php中文网

原创

100vh 在移动端常“不够高”是因为 safari 地址栏动态遮盖视口,导致 100vh 取初始高度而滚动后错位;应改用 min-height: 100dvh,并确保 html/body 显式设高,grid 才能正确布局。

css网格实现全屏布局_vh单位与grid的完美结合案例

为什么 100vh 在移动端经常“不够高”?

因为 Safari(尤其是 iOS)的地址栏和底部工具栏会动态遮盖/释放视口高度,100vh 取的是初始布局时的视口高度,滚动后可能被截断或留白。这不是 Grid 的问题,而是 vh 单位本身的局限。

  • 实际场景:全屏轮播、登录页、单页应用根容器
  • 真实表现:iOS 上滚动后底部空白、内容被切掉、按钮点不中
  • 替代方案不是换单位,而是用 min-height: 100dvh(推荐)或 height: 100svh
  • dvh = dynamic viewport height,浏览器会随地址栏显隐实时更新,目前 Chrome 105+、Safari 16.4+、Firefox 114+ 支持;svh 是 small viewport height,取“最小可能视口”,更保守但兼容略差

Grid 全屏布局必须设 htmlbody 高度吗?

必须。Grid 容器的高度依赖父级约束,而默认 htmlbody 没有显式高度,100vh100dvh 就没意义。

  • 错误写法:main { display: grid; height: 100vh; } —— 如果 body 没撑开,main 高度就是 0
  • 正确顺序:
    html, body { margin: 0; height: 100%; }
    body { display: grid; min-height: 100dvh; }
  • 不要用 height: 100dvh 直接设在 body 上(部分旧版 Safari 不认),优先用 min-height
  • 若项目需支持 iOS 15.4 以下,可降级为 JS 动态设置:document.body.style.height = <code>${window.innerHeight}px,但仅作兜底

grid-template-rows: 1fr100% 有什么区别?

1fr 是 Grid 的弹性分配单元,基于可用空间计算;100% 是相对父元素高度的百分比,父元素若无高度则无效。

uBrand
uBrand

一站式AI品牌创建平台,在线品牌设计,AI品牌策划,智能品牌营销;uBrand帮助创业者轻松打造个性品牌!

下载
  • 常见坑:grid-template-rows: 100% 在全屏布局里基本没用,因为父容器高度来自 min-height: 100dvh,而百分比高度只对 height 生效,不对 min-height 生效
  • 正确组合:grid-template-rows: 1fr + min-height: 100dvh,让 Grid 自动填满剩余空间
  • 多区域场景示例:grid-template-rows: auto 1fr auto —— 头部自适应、主体占满剩余、底部自适应,这才是 Grid 的优势所在

键盘弹出时 iOS 页面被顶起,怎么防止 Grid 布局错乱?

这不是 Grid 的 bug,是 iOS Webkit 的输入框聚焦行为触发了视口缩放与重排。Grid 容器本身不会“错乱”,但子元素可能因视口突变而位置偏移或溢出。

立即学习前端免费学习笔记(深入)”;

  • 关键动作:监听 focusinblur,临时给 bodyposition: fixed(慎用)或用 scrollIntoView({ block: 'nearest' }) 控制焦点位置
  • 更稳妥做法:避免让输入框位于视口底部;用 viewport meta 的 height=device-height 无济于事,已被现代 Safari 忽略
  • 真实兼容建议:对 inputtextarea 添加 scroll-margin-top: 60px,确保聚焦时内容不被键盘盖住

有些细节没法靠一个 CSS 属性解决,比如 dvh 的渐进支持、iOS 键盘和视口的博弈、Grid 子项的内在尺寸继承逻辑——这些地方一旦漏掉,调试起来反而比 Flex 慢。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

981

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

801

2023.11.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

524

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

454

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

617

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5736

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

491

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

217

2023.09.04

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.4万人学习

CSS教程
CSS教程

共754课时 | 35万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号