css grid布局中行和列是如何定义的_利用gridtemplaterows和columns说明
发布时间 - 2026-02-03 00:00:00 点击率:次grid-template-rows和grid-template-columns是定义显式网格的必需属性,必须写在容器上,值为轨道尺寸序列;fr单位按剩余空间分配,非百分比;repeat()配合auto-fit和minmax()可实现响应式列布局;隐式网格需用grid-auto-rows等控制溢出项高度。
grid-template-rows 和 grid-template-columns 是定义显式网格的唯一直接方式
它们不是“可选配置”,而是你画出网格骨架的必需笔触。只要没写这两个属性,display: grid 只创建了一个空容器——没有行、没有列、没有轨道,后续的 grid-column 或 grid-row 会默认落到隐式网格里,行为难以预测。
- 二者必须写在**容器元素**上,子项无法通过自身样式定义行列结构
- 值是一组用空格分隔的轨道尺寸(track size),顺序即从左到右(列)、从上到下(行)
- 不支持简写合并成一个属性;
grid-template虽能整合,但语法更复杂且可读性差,不推荐新手用 - 若只定义了
grid-template-columns而没写grid-template-rows,所有子项将堆叠在第一行——这不是 bug,是规范行为
fr 单位不是“百分比”,它是剩余空间的弹性切片
很多人误以为 1fr ≈ 33.33%,其实它只在所有轨道都用 fr 时才等效。一旦混入 px、% 或 auto,计算逻辑立刻变化。
-
grid-template-columns: 200px 1fr 2fr:先扣掉 200px 固定宽度,剩下空间按 1:2 切成两份,不是按总宽三等分 -
grid-template-columns: 1fr 1fr auto:前两列平分“减去 auto 列内容宽度后的剩余空间”,auto列由自身内容撑开,可能挤压其他列 - 避免在同一个轨道列表里混用
%和fr——%相对于容器宽,fr相对于剩余空间,两者基准不同,结果难推演
repeat() 不只是缩写,它是响应式布局的关键杠杆
repeat(4, 1fr) 看似只是 1fr 1fr 1fr 1fr 的简写,但它真正价值在于配合 auto-fit 和 minmax() 实现自动列数调整。
-
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr))):每列至少 250px,容器够宽就多放一列,不够就自动换行——无需媒体查询 -
repeat(3, 100px)和100px 100px 100px渲染完全
一致,但前者更易维护,尤其当列数达 6+ 时
- 别对
grid-template-rows盲目套用repeat(auto-fit...):行高通常依赖内容,auto-fit在行方向效果有限,更适合列布局
显式网格之外还有隐式网格,漏设 grid-auto-rows 会导致高度失控
当你有 10 个子项,但只定义了 grid-template-rows: 60px 80px(仅两行),浏览器会自动生成第 3、4… 行来容纳剩余项目——这些就是隐式行,其高度默认为 auto,也就是由内容撑开。
- 后果:卡片高度不一致、底部留白突兀、滚动体验割裂
- 修复:加一句
grid-auto-rows: minmax(120px, auto),保证所有隐式行最小 120px,内容多时仍可伸展 - 注意:
grid-auto-rows不影响显式定义的行,只管“多出来的那些行” - 同理,
grid-auto-columns用于控制超出显式列数时的列宽,但实际中列溢出较少见
.container {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)));
grid-template-rows: 72px; /* 头部固定高 */
grid-auto-rows: minmax(140px, auto); /* 其余行统一基线 */
gap: 16px;
}显式网格定义的是你“计划中的结构”,而隐式网格处理的是“现实中的意外”。跳过 grid-auto-rows 就像只设计楼层不考虑承重,表面能用,一加内容就露馅。
# css
# 浏览器
# ai
# 响应式布局
# 一加
# grid布局
# auto
# 堆
# 切片
# display
# column
# bug
# 隐式
# 的是
# 它是
# 相对于
# 写在
# 切成
# 也就
# 一句
# 是由
# 很多人
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives
Android中AutoCompleteTextView自动提示
中山网站制作网页,中山新生登记系统登记流程?
使用豆包 AI 辅助进行简单网页 HTML 结构设计
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
油猴 教程,油猴搜脚本为什么会网页无法显示?
浅析上传头像示例及其注意事项
如何快速搭建高效可靠的建站解决方案?
PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑
详解Oracle修改字段类型方法总结
谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复
香港服务器如何优化才能显著提升网站加载速度?
在线制作视频的网站有哪些,电脑如何制作视频短片?
Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】
如何用PHP快速搭建CMS系统?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
香港服务器WordPress建站指南:SEO优化与高效部署策略
如何用PHP工具快速搭建高效网站?
利用python获取某年中每个月的第一天和最后一天
google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤
如何快速搭建安全的FTP站点?
Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】
Laravel怎么实现验证码(Captcha)功能
详解jQuery中的事件
如何在腾讯云服务器上快速搭建个人网站?
如何为不同团队 ID 动态生成多个非值班状态按钮
利用 Google AI 进行 YouTube 视频 SEO 描述优化
香港服务器租用每月最低只需15元?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
大型企业网站制作流程,做网站需要注册公司吗?
香港服务器租用费用高吗?如何避免常见误区?
如何在万网自助建站中设置域名及备案?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
MySQL查询结果复制到新表的方法(更新、插入)
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
如何用花生壳三步快速搭建专属网站?
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
Laravel如何创建和注册中间件_Laravel中间件编写与应用流程
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
python中快速进行多个字符替换的方法小结
想要更高端的建设网站,这些原则一定要坚持!
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
中山网站推广排名,中山信息港登录入口?
Win11怎么开启自动HDR画质_Windows11显示设置HDR选项
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
java获取注册ip实例
使用spring连接及操作mongodb3.0实例


