css `svh` 单位

svh 是css中的一个视口相对单位。表示小视口高度(small viewport height。), 他为了解决移动设备上浏览器窗口尺寸变化的问题引入的单位。

  • 小视口指的是浏览器界面最小时的视口尺寸

  • 在移动设备上,当地址栏、工具栏等浏览器UI元素完全展开时,此时的视口高度就是小视口高度

  • 与 dvh(动态视口高度)和 lvh(大视口高度)形成对比

单位 全称 描述 适用场景
svh Small Viewport Height 浏览器UI最大时的视口高度 保证内容始终可见
lvh Large Viewport Height 浏览器UI最小时的视口高度 全屏体验
dvh Dynamic Viewport Height 动态变化的视口高度 响应UI变化
css 复制代码
/* 元素高度始终为小视口高度的100% */
.full-height {
  height: 100svh;
}

/* 响应式设计中的使用 */
.container {
  /* 最小高度为小视口高度 */
  min-height: 100svh;
  
  /* 回退方案 */
  min-height: 100vh;
}
使用场景
  1. 响应式设计中,保证内容始终可见
css 复制代码
/* 确保按钮始终在可视区域内 */
.cta-button {
  position: fixed;
  bottom: 20px;
  /* 使用svh确保即使在地址栏展开时也能看到 */
  max-height: calc(100svh - 100px);
}
  1. 全屏体验
css 复制代码
.hero-section {
  /* 使用svh而不是vh,避免地址栏遮挡 */
  height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 1rem;
}
  1. CSS自定义属性结合使用
css 复制代码
:root {
  --svh: 100svh;
  --safe-area: env(safe-area-inset-bottom, 0px);
}

.container {
  height: calc(var(--svh) - var(--safe-area));
}
  1. JavaScript获取小视口尺寸
javascript 复制代码
// 获取小视口高度
const smallViewportHeight = window.visualViewport?.height ||  Math.min(window.innerHeight, window.outerHeight);

// 设置为CSS自定义属性
document.documentElement.style.setProperty('--svh', `${smallViewportHeight}px`);

注意事项

性能考虑:与 dvh 不同,svh 值不会随UI变化而改变,性能更好

内容截断风险:使用 svh 时,如果内容过多可能被截断,需要配合 overflow

相关推荐
夏幻灵9 小时前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_9 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝9 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions9 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发9 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_9 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞059 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
我爱加班、、10 小时前
Websocket能携带token过去后端吗
前端·后端·websocket
AAA阿giao10 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
杨超越luckly10 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强