CSS 视口单位:CSS *vh(dvh、lvh、svh)和 *vw 单位
时间:2025-01-17 22:31:12 450浏览 收藏
今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《CSS 视口单位:CSS *vh(dvh、lvh、svh)和 *vw 单位》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!
CSS视口单位是构建响应式网页设计的基石,它们根据浏览器视口(可见区域)的尺寸动态调整元素大小,让网站在各种屏幕尺寸下都能保持最佳显示效果。本文将深入探讨常用的vh
、vw
以及更高级的dvh
、lvh
、svh
单位,并讲解如何利用它们创建更灵活、更强大的响应式布局。
1. 理解CSS视口单位
视口单位是相对单位,其值取决于浏览器视口的宽度或高度。最常用的有:
vh
(viewport height): 视口高度的1%。 例如,height: 50vh;
将元素高度设置为视口高度的一半。vw
(viewport width): 视口宽度的1%。例如,width: 25vw;
将元素宽度设置为视口宽度的四分之一。
2. vh
和 vw
的局限性
尽管vh
和vw
简单易用,但在处理动态变化的视口时存在一些局限性:
- 浏览器UI元素: 地址栏、工具栏等浏览器UI元素会占用视口空间,导致
vh
和vw
计算结果与预期不符。 - 设备方向变化: 旋转设备会改变视口尺寸,造成布局的瞬间变化。
3. 更高级的视口单位:dvh
、lvh
、svh
为了克服vh
和vw
的不足,CSS引入了dvh
、lvh
和svh
:
dvh
(dynamic viewport height): 动态视口高度,考虑了浏览器UI元素的影响,始终反映可见视口的高度。lvh
(layout viewport height): 布局视口高度,忽略浏览器UI元素,表示视口最大可能的高度。svh
(small viewport height): 最小视口高度,适用于键盘等UI元素可能占据大量空间的场景。
4. vw
的应用
vw
单位不受浏览器UI元素或设备方向变化的影响,始终表示视口宽度的1%。它常用于创建水平方向的响应式布局,例如:
div {
width: 100vw; /* 占据整个视口宽度 */
background-color: lightpink;
}
5. 实际应用案例
- 响应式英雄区:
.hero {
height: 100dvh; /* 适应可见视口高度 */
width: 100vw;
background: url('hero.jpg') no-repeat center center/cover;
}
- 全屏模态框:
.modal {
height: 100svh; /* 适应最小视口高度,即使键盘弹出也能正常显示 */
width: 100vw;
overflow-y: auto; /* 允许滚动 */
background-color: white;
}
- 固定底部栏:
footer {
height: 10lvh; /* 保持一致的高度,不受浏览器UI元素影响 */
width: 100vw;
background-color: darkgray;
}
6. 灵活组合视口单位
为了实现更精细的控制,可以组合使用不同的视口单位:
.container {
min-height: 100svh; /* 保证在最小视口下也能正常显示 */
height: 100dvh; /* 填充可见视口高度 */
max-height: 100lvh; /* 防止超出最大视口高度 */
}
7. 浏览器兼容性
vh
和vw
得到广泛支持,但dvh
、lvh
和svh
相对较新,需注意浏览器兼容性,并为旧浏览器提供备用方案。
8. 结论
CSS视口单位是创建响应式和自适应网页设计的关键。 理解并灵活运用vh
、vw
、dvh
、lvh
和svh
,可以构建出在各种设备和屏幕尺寸下都能完美呈现的网页,提升用户体验。 尤其对于移动应用开发者来说,掌握这些单位至关重要。
到这里,我们也就讲完了《CSS 视口单位:CSS *vh(dvh、lvh、svh)和 *vw 单位》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
226 收藏
-
468 收藏
-
305 收藏
-
259 收藏
-
369 收藏
-
491 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习