CSSGrid固定列与自适应列设置技巧
时间:2026-02-18 11:08:05 286浏览 收藏
本文深入讲解了如何利用CSS Grid的`grid-template-columns`属性,通过混合使用像素值(如200px)与`fr`单位(如1fr、2fr),高效实现固定列与自适应列的灵活组合布局——无论是两栏(左固定右伸缩)、三栏(两侧固定中间自适应),还是多自适应列按比例分配,都能简洁精准地完成;更结合媒体查询实现移动端单列堆叠,让响应式设计变得直观、可靠且无需依赖浮动或复杂计算,是现代网页布局的首选实践方案。

要实现CSS中固定列与自适应列的组合布局,使用 Grid 布局(CSS Grid) 是最简洁高效的方式。通过 grid-template-columns 属性,可以轻松定义某些列为固定宽度(如 200px),其他列自动填充剩余空间。
基本思路:使用 fr 单位与固定单位混合
Grid 提供了 fr(fraction)单位,表示“可用空间的份数”。将固定列设为像素值(如 200px),自适应列用 1fr 或多个 fr 比例,即可实现灵活布局。
示例:左侧固定 200px,右侧占满剩余空间
.container {
display: grid;
grid-template-columns: 200px 1fr;
gap: 16px;
height: 100vh;
}
此时容器分为两列:第一列固定 200px 宽,第二列自动伸缩,占据剩余宽度。
多列混合布局:固定 + 自适应 + 固定
常见于三栏布局,如侧边栏 + 主内容 + 右侧工具栏。
示例:左栏 200px,中间自适应,右栏 100px.container {
display: grid;
grid-template-columns: 200px 1fr 100px;
gap: 12px;
height: 100vh;
}
中间列会随窗口变化自动调整宽度,两侧保持固定。
多个自适应列按比例分配
如果需要多个弹性列,可以用多个 fr 值设置比例。
.container {
display: grid;
grid-template-columns: 240px 2fr 1fr;
gap: 20px;
}
右侧两列将按 2:1 的比例共享除 240px 外的所有水平空间。
响应式中的灵活应用
结合媒体查询,可在不同屏幕下调整列行为。
移动端适配示例:@media (max-width: 768px) {
.container {
grid-template-columns: 1fr; /* 小屏下变为单列 */
}
}
在移动设备上堆叠显示,提升可读性。
基本上就这些。利用 grid-template-columns 混合使用像素值和 fr 单位,能快速构建稳定且响应式的固定+自适应布局,无需计算百分比或使用浮动等过时方法。
本篇关于《CSSGrid固定列与自适应列设置技巧》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
347 收藏
-
458 收藏
-
110 收藏
-
422 收藏
-
404 收藏
-
127 收藏
-
216 收藏
-
465 收藏
-
116 收藏
-
112 收藏
-
465 收藏
-
492 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习