CSS容器查询实战
用容器查询构建真正组件级响应式布局,摆脱仅依赖视口尺寸的限制
2024年3月5日
2 min read
CSS响应式容器查询前端
前言
媒体查询基于视口宽度做判断,适合页面级布局。但在组件复用场景中,组件所在容器大小更关键。
容器查询的核心思路
容器查询让组件根据父容器尺寸自适应,而不是根据全局视口。
1. 标记容器
.card-list {
container-type: inline-size;
container-name: list;
}2. 编写容器查询
@container list (min-width: 600px) {
.card {
grid-template-columns: 160px 1fr;
}
}实战示例
在侧边栏与主内容区复用同一张卡片时,使用容器查询可以自动切换布局。
.card {
display: grid;
grid-template-columns: 1fr;
gap: 12px;
}
@container (min-width: 480px) {
.card {
grid-template-columns: 120px 1fr;
}
}常见问题
- 记得给父容器设置
container-type - 仅在需要时使用,避免过度嵌套
- Safari需要较新版本支持
总结
容器查询让组件真正“自适应”,在设计系统中价值尤其明显。