如何用css grid实现动态调整列宽布局

使用 fr 单位、minmax() 和 auto-fit 可实现 CSS Grid 动态列宽布局:1. fr 按比例分配空间,如 1fr 2fr 或混合固定宽度;2. minmax() 设定列宽范围,如 minmax(100px, 1fr) 防止过窄或过宽;3. repeat(auto-fit, minmax(150px, 1fr)) 实现自适应列数与换行;4. gap 自动处理间距,避免溢出。组合使用可无需媒体查询实现响应式布局

如何用css grid实现动态调整列宽布局

使用 CSS Grid 实现动态调整列宽布局,关键是利用 fr 单位、minmax()auto-fitauto-fill 等特性,让网格列根据容器空间和内容自动伸缩。下面介绍几种常用方法。

1. 使用 fr 单位实现比例分配

fr(fraction)单位表示可用空间的比例分配,适合创建等比或按权重分配的列宽。

例如:

grid-template-columns: 1fr 2fr; 表示第一列占1份,第二列占2份,总共3份,自动填充容器宽度。

如果希望某些列固定宽度,其他列自适应:

grid-template-columns: 100px 1fr 2fr; —— 第一列固定100px,后两列按1:2比例分配剩余空间。

立即学习“前端免费学习笔记(深入)”;

2. 使用 minmax() 控制最小和最大列宽

结合 minmax() 可以设置列的最小和最大宽度,实现更灵活的响应式布局。

常见用法:minmax(100px, 1fr):列最小100px,最大可扩展到1fr的空间。 minmax(max-content, 200px):内容撑开但不超过200px。

适合内容长度不固定的场景,避免列过窄或过宽。

3. 使用 auto-fit 和 repeat 实现自动换行与填充

想让列数根据容器大小自动调整,可以用:

Seede AI Seede AI

AI 驱动的设计工具

Seede AI 586 查看详情 Seede AI

grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));

解释:auto-fit:自动填充可用空间,空列会被合并到现有列中。 minmax(150px, 1fr):每列至少150px,多余空间平均分配。

当容器变窄时,列会自动换行并重新计算数量,适合卡片布局或相册展示。

4. 结合 gap 实现间距自适应

使用 gap 设置列与行之间的间距,Grid 会自动在计算时排除这些间隙,避免溢出。

例如:

gap: 10px;column-gap: 16px; row-gap: 8px;

Grid 会自动处理间距对列宽的影响,无需手动计算。

基本上就这些。通过 fr、minmax 和 auto-fit 的组合,可以轻松实现列宽随内容和容器动态调整的布局,无需媒体查询也能达到良好响应效果。关键在于理解每个函数的作用和它们如何协同工作。不复杂但容易忽略细节。

以上就是如何用css grid实现动态调整列宽布局的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1070480.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 07:10:38
下一篇 2025年12月2日 07:10:59

相关推荐

  • 欧洲虚拟币交易平台排行榜2025年最新榜单TOP10盘点(最近更新)

    随着数字资产市场的日益成熟,选择一个安全可靠的交易平台对于欧洲用户至关重要。本文旨在盘点2025年欧洲地区表现最出色的十大虚拟货币交易平台,帮助您做出明智选择。 我们的评选标准综合考虑了平台的合规性、安全性、交易费用、支持的资产种类以及用户体验,力求为初学者和资深交易者提供一份权威参考。 欧洲虚拟币…

    2025年12月8日 好文分享
    000
  • Web3.0是什么意思?和Web2有啥区别?

    web3.0,常被称为去中心化网络,代表着互联网演进的下一阶段。它建立在现有互联网技术之上,但核心理念与web2.0存在显著差异。web2.0是我们目前广泛使用的互联网模式,其特点是用户生成内容以及大型中心化平台的主导地位。理解web3.0,需要对比其在架构、数据、技术栈等方面的根本性转变。 核心架…

    2025年12月8日
    000
  • 2025合规SAHARA交易所TOP10

    一键直达|2025主流加密资产交易所平台 Binance币安 Huobi火币 欧易OKX 2025年合规SAHARA交易所TOP10——全球最具监管资质的平台评选 随着全球对数字资产监管逐步明晰,合规性已成为衡量交易所可信度与可持续性的核心指标。对于SAHARA等新兴资产而言,选择合规交易所,不仅保…

    2025年12月8日
    000
  • 云母规则,欧洲委员会和欧洲央行警告:导航欧盟加密货币景观

    探索云母规则,欧盟委员会的潜在调整以及欧洲央行在不断发展的欧盟加密货币市场中的警告之间的紧张局势。 云母规则、欧洲委员会与欧洲央行警告:解读欧盟加密格局 当前,围绕云母规则的讨论成为欧洲加密市场的焦点。随着欧盟委员会考虑可能的修改,同时面对欧洲央行的警示声音,我们一起来梳理这一系列动态及其对欧洲加密…

    2025年12月8日
    000
  • Pipe Network(PIPE)币是什么?如何运作?PIPE代币经济学介绍

    目录 Pipe Network代币(PIPE)是什么?Pipe Network为何诞生?Pipe Network如何运作?Pipe Network产品与技术Pipe Network守护节点去中心化 CDN(PoP 节点基础设施)Pipe Network开发人员 API 和 SDK实时数据流层数据治理…

    2025年12月8日 好文分享
    000
  • 什么是 Pipe Network (PIPE)?运作方式、特点、PIPE 代币经济学介绍

    在 depin 热潮中,pipe network 应运而生,成为一个开创性的基础设施项目,为 cloudflare 和 akamai 等中心化内容分发网络 (cdn) 提供了替代方案。pipe network 建立在 solana 区块链之上,利用去中心化模型来优化速度、降低延迟,并比以往更轻松地扩…

    2025年12月8日 好文分享
    000
  • 个人买u卖u合法吗?正规合法买u卖u平台前十推荐

    个人买U卖U是否合法? 在许多国家和地区,个人买卖比特币是合法的,但具体的法律法规因国家和地区的不同而有所差异。在部分地区,个人买卖比特币不被禁止,但必须遵守相关的法律法规,如反洗 钱和反恐怖主义融资法规。个人在进行比特币交易时,需确保交易行为符合当地法律要求。 如何确保个人买U卖U的合法性? 为了…

    2025年12月8日 好文分享
    000
  • 2025年度数字资产交易所综合实力排行榜前十汇总

    在2025年,数字资产交易所的竞争愈发激烈,市场上涌现出许多实力强劲的平台。以下是对2025年度综合实力排行榜前十的数字资产交易所的详细汇总,涵盖了每个交易所的关键特点、服务、安全性以及用户体验。 1. Binance(币安)  核心优势:流动性全球第一,日交易量超千亿美元,覆盖600+币种,新币首…

    2025年12月8日 好文分享
    000
  • 2025-W未流通的美国银鹰以创纪录的$ 91价格首次亮相

    美国造币局推出了2025-W未发行的美国银鹰,售价为91美元,这一价格创造了硬币历史上的新高点。 ![](data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wCEAAkGBwgHBgkIBwgKCgkLDRYPDQwMDRsUFRAWIB0iIi…

    2025年12月8日
    000
  • Binance Coin(BNB)以$ 680的抵抗力为MANTIX(MTX)PRESALE增长动量

    据顶尖交易员追踪其最新动态的报告显示,Binance Coin(BNB)在680美元的价位上遭遇了强劲的阻力。与此同时,BNB正努力突破更高的目标。 ![](data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wCEAAkGBwgHBgkIBwgK…

    2025年12月8日
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • 优化PDF中下载链接的URL显示:利用HTML title 属性

    在pdf文档中,当包含下载链接时,完整的url路径通常会在鼠标悬停时或直接显示在链接文本中,这可能不符合预期。本文将探讨为何传统方法如`.htaccess`重写或javascript不适用于pdf环境,并提出一种利用html “ 标签的 `title` 属性来定制链接悬停显示文本的解决方…

    2025年12月6日 后端开发
    000
  • Phaser 3 游戏画布响应式适配:保持高度控制宽度

    本文旨在提供一种在 Phaser 3 游戏中实现画布响应式适配的方案,核心思路是利用 `Phaser.Scale.HEIGHT_CONTROLS_WIDTH` 缩放模式,使画布高度适应父容器,宽度随之调整,并始终居中显示。这种方法适用于需要保持游戏核心内容在屏幕中央,允许左右裁剪的场景。 在 Pha…

    2025年12月6日 web前端
    000
  • Phaser 3游戏画布响应式布局:实现高度适配与宽度裁剪

    本文深入探讨phaser 3游戏画布在特定响应式场景下的布局策略,尤其是在需要画布高度适配父容器并允许左右内容裁剪时。通过结合phaser的scalemanager中的`height_controls_width`模式与精细的css布局,本教程将展示如何实现一个既能保持游戏画面比例,又能完美融入不同…

    2025年12月6日 web前端
    000
  • JavaScript数据可视化进阶

    答案是%ignore_a_1%进阶需以叙事为核心,结合工具深度与交互设计。首先理解场景,选用D3.js、Chart.js或ECharts等工具,挖掘其数据驱动、动态更新与插件扩展能力;其次优化性能,通过Web Workers、LTTB算法和Canvas渲染处理大规模数据;再者增强交互,实现跨图表联动…

    2025年12月6日 web前端
    000
  • PDF文档中隐藏下载链接真实路径的教程

    本教程旨在解决pdf文档中下载链接显示完整url路径的问题,尤其是在鼠标悬停时暴露动态参数。文章将解释为何传统的.htaccess重写或javascript方法不适用于pdf环境,并提出一种利用html “标签的`title`属性来控制链接提示文本的有效策略,从而在不影响功能的前提下,优…

    2025年12月6日 后端开发
    000
  • JavaScript SVG动态矢量图形处理

    JavaScript结合SVG可实现高效动态图形处理,通过createElementNS创建带命名空间的SVG元素,动态生成如圆形等图形;利用setAttribute实时修改属性实现交互响应;借助requestAnimationFrame或事件驱动完成平滑动画;基于数据映射生成路径,支持折线图等复杂…

    2025年12月6日 web前端
    000
  • 如何在安装完成后优化缓存使用

    合理配置缓存策略可提升系统效率,需设置适宜的过期时间、选用多层存储介质并持续监控维护。 安装完成后优化缓存使用,关键在于合理配置缓存策略、选择合适的存储方式,并定期维护。以下是一些实用建议,帮助你提升系统或应用的缓存效率。 合理设置缓存过期时间 缓存的有效期直接影响数据的新鲜度和性能表现。设置过短会…

    2025年12月6日 数据库
    000
  • Chrome扩展开发:解决图片资源加载失败的完整指南

    本文详细阐述了chrome扩展程序中图片资源加载失败的常见原因及解决方案。核心在于理解`manifest.json`中的`web_accessible_resources`配置,并掌握在内容脚本或动态生成元素中通过`chrome.runtime.geturl()`函数正确引用扩展内部图片资源的最佳实…

    2025年12月6日 web前端
    000
  • 如何管理和同步VSCode的扩展配置,以便在新设备上快速恢复开发环境?

    使用 Settings Sync 是最快方式,通过 GitHub 账号同步扩展、设置、快捷键和代码片段;也可手动导出扩展列表(code –list-extensions > extensions.txt)并在新设备安装,结合备份 settings.json 等配置文件实现环境快速恢…

    2025年12月6日 开发工具
    000

发表回复

登录后才能评论
关注微信