当前位置: 首页 > news >正文

Tailwind CSS `shrink-0`是啥意思?

Tailwind CSS近几年大受欢迎,github一些炙手可热的项目有的都用上了。


原子化 和 语义化 的区别

tailwind 是属于原子化css这种类型的。

语义化

之前我们常写的有语义化css,代码如下:

.chat { display: flex; max-width: 24rem; margin: 0 auto; padding: 2rem; }

原子化

原子 化是更加关注css,代码如下:

<div class="p-6 max-w-sm flex items-center"></div>

用写class来表示css规则,比如:

bg-white 代表background-color: white;

这种的话就比较适合那种没有设计师具体到哪个像素,具体到什么什么单位的。适合独立开发或者小公司,前端去做中后台管理系统那种。


在使用 Flexbox 创建响应式布局时,控制元素是否“收缩”是个非常关键的问题。

Tailwind 提供了一个非常实用的类:shrink-0,它能让你的某些元素在容器空间不足时保持原样不被压缩。本文将带你彻底搞懂它的原理、用法与最佳实践。


什么是shrink-0

简单来说,shrink-0就是flex-shrink: 0的快捷写法。默认情况下,所有 Flex 子元素都有flex-shrink: 1,也就是说当空间不足时,它们会按比例变小。而shrink-0则禁止这一行为——该元素保持自己的尺寸,不管父容器有多小。

用途包括:

  • 保证 logo、头像、图片等关键元素不被压缩;
  • 实现左右固定+中间弹性布局;
  • 创建稳定的卡片排版结构。

它到底怎么运作?

flex-shrink是个比例因子。假设容器不足以容纳所有项目,就会出现“负空间”。浏览器会根据每个子项的flex-shrink值和大小,计算应该压缩多少。

公式如下:

收缩量 = (该项目 shrink × 它的原始宽度) / 所有项目 shrink*宽度之和 × 负空间

如果你设置的是shrink-0,那它乘上原始宽度就是 0,自然就不会被压缩了。

实战演示

示例一:防止图片被压缩

<div class="flex w-64 border"> <div class="shrink-0 w-32 h-32 bg-blue-500 text-white flex items-center justify-center"> 固定宽度 </div> <div class="p-4 bg-red-500 text-white"> 内容会根据空间自动收缩 </div> </div>

示例二:导航栏中的应用

<nav class="flex items-center bg-gray-800 text-white p-4"> <div class="shrink-0 mr-4"> <svg class="w-8 h-8" viewBox="0 0 20 20">...</svg> </div> <div class="flex space-x-4 overflow-x-auto"> <a href="#">首页</a> <a href="#">产品</a> <a href="#">服务</a> </div> <div class="shrink-0 ml-auto"> <button class="bg-gray-700 p-2 rounded-full">用户</button> </div> </nav>

响应式技巧 & 高阶玩法

  • 响应式收缩控制
<div class="flex"> <div class="shrink md:shrink-0 w-32 bg-blue-500">小屏收缩,大屏固定</div> <div class="flex-1 bg-gray-100">内容</div> </div>
  • flex-1组合:
<div class="flex min-h-[200px]"> <div class="shrink-0 w-48 bg-gray-200">固定侧边栏</div> <div class="flex-1 bg-white">主内容</div> </div>
  • 动态交互 + 过渡效果:
<div class="flex"> <div class="shrink-0 hover:shrink transition-all duration-300 w-32 h-32 bg-green-500"> 悬停时尝试收缩 </div> <div class="flex-1 bg-yellow-500">其他内容</div> </div>

常见疑问

  • shrink-0flex-none有啥区别?

    • shrink-0只设置了不收缩;
    • flex-noneflex: none,包括不增长、不收缩、宽度自适应。
  • shrink-0没效果?

    • 父元素可能没有加flex
    • 容器空间够用时自然不会收缩
    • 元素本身宽度设置不合理

最佳实践小贴士

  • 保住关键内容不被压缩(如:Logo、图标、按钮)
  • 配合overflow-auto实现优雅滚动
  • 长列表中慎用(避免渲染性能问题)
  • 响应式控制:小屏可收缩,大屏固定显示

总结一句话

只要你想“锁住”某个元素,让它不管外界怎么变都不缩水,shrink-0就是你的好帮手

http://www.rkmt.cn/news/1469231.html

相关文章:

  • 2026军校近视手术康复指南:顺利通关全流程解析
  • 2026苏州好评多的防水补漏服务商深度解析:资质、技术与场景适配综合评估 - 鼎壹万修缮说
  • 【RT-DETR实战】137、Transformer模型压缩:从RT-DETR实战看TinyViT的轻量化哲学
  • 2026苏州本土专业防水补漏公司综合测评:技术体系与服务能力深度解析 - 鼎壹万修缮说
  • 美股是否处于估值偏高状态
  • 软件开发外包新手避坑指南:首次合作零翻车的实战标准流程
  • 2026苏州靠谱防水补漏合作渠道测评:技术实力、服务效率与场景适配性分析 - 鼎壹万修缮说
  • B站CC字幕一键下载转换:告别手动抄录,3分钟搞定视频字幕提取
  • 提升 Shopify 转化率的 10 个实战技巧
  • 终极指南:如何用StreamFX插件让OBS直播画面瞬间专业化
  • Veo 2运动设置避坑清单,2024最新版:3类误触触发、2种IMU漂移陷阱、1个不可逆校准风险
  • YOLOv11涨点改进| ICCV 2025 | 独家创新、特征融合改进篇| 引入I-SCA / V-SCA特征融合模块,含多种创新改进,助力图像融合、小目标检测、图像分割、多模态融合检测高效涨点改进
  • 终极性能调优指南:3分钟掌握Universal x86 Tuning Utility的强大功能
  • 效率提升秘籍:用快马AI生成pytest参数化与并发测试配置
  • 基于 Python + MySQL 的公交线路查询与管理系统(附源码)
  • TypeScript 快速上手指南:从 JavaScript 到类型安全
  • AI新闻日报 · 2026-06-03
  • 解读民法典自然人 民事权利能力和民事行为能力 第二十四条
  • 基于小程序的球队训练信息管理系统毕设源码
  • 2026上海小程序开发公司排名:企业做小程序定制开发怎么选?
  • Gitee 企业版测试管理功能迎来全面升级:打通研发闭环,让流程更顺畅,交付更可靠
  • 【RT-DETR实战】140、实验管理与超参数优化工具实战笔记:从混乱到秩序
  • 安装mysql时报错This application requires Visual Studio 2013 Redistributable. Please install the Redistrib
  • OneMore插件:160+功能让你的OneNote成为专业笔记管理利器
  • 遇上 Bug 别慌:用 GPT-5.5 + Claude 3.5 双重验证解决复杂代码报错
  • 艺学启航:编程语言性能实测:不同项目精准选型指南
  • 数据库语句 触发器 作业
  • 微信与手机厂商合作推A2A助手,超级App与系统级AI助手争夺AI时代入口
  • 如何用PyVista实现专业级3D可视化:从数据到洞察的完整指南
  • 3大3D渲染范式革新:F3D如何重塑跨平台可视化技术栈