news 2026/1/29 13:49:40

css样式用flex 布局的时候元素尺寸展示不对

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
css样式用flex 布局的时候元素尺寸展示不对

问题描述

我的代码是148px宽度,但是实际上显示的只有133px

问题根源

在 Flex 布局中,flex-shrink是flex 子元素的收缩属性,默认值是1,意思是:

  • 当父元素的宽度不足以容纳所有子元素的宽度总和时,子元素会按照flex-shrink的数值比例自动收缩,以适应父元素的宽度。
  • 你写的.main作为 flex 子元素时,因为flex-shrink: 1,父元素宽度不够的情况下,它就被收缩了 6px(164px →148px)。
    你确认了问题根源是flex-shrink的默认收缩行为导致.main的宽度被压缩,从164px变成了148px,我会帮你梳理这个问题的本质和最终的解决方案。

二、最终修复后的完整代码

我把flex-shrink: 0添加到你的.main样式中,确保宽度不会被收缩:

.main { width: 164px; /* 你期望的宽度 */ height: 100%; background: #f8fafc; display: flex; align-items: center; padding: 24px 0px; flex-direction: column; gap: 6px; flex-shrink: 0; /* 禁止flex收缩,固定宽度 */ .item { width: 132px; height: 40px; } .line { width: 108px; height: 1px; } }

三、补充:flex布局的三个核心属性

为了让你更好地掌握flex子元素的尺寸控制,这里简单说明flex的三个核心属性:

属性作用默认值
flex-grow子元素的放大比例0(不放大)
flex-shrink子元素的收缩比例1(自动收缩)
flex-basis子元素的初始宽度/高度auto(默认取元素自身尺寸)

日常开发中,也可以用简写flex: 0 0 164px;(等价于flex-grow: 0; flex-shrink: 0; flex-basis: 164px;),直接固定子元素的宽度,更简洁。

总结

  1. 问题根源是flex-shrink: 1的默认行为,导致.main在父元素宽度不足时被收缩,宽度从164px变为148px。
  2. 添加flex-shrink: 0;可以禁止flex子元素的收缩行为,让.main的宽度保持为你设置的164px。
  3. 也可以使用flex: 0 0 164px;简写形式,一次性设置放大、收缩和初始宽度,更高效。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/27 23:08:10

13、BPF 流量控制分类器详解

BPF 流量控制分类器详解 1. 流量控制概述 流量控制(Traffic Control)是内核数据包调度子系统架构,由机制和排队系统组成,可决定数据包的流动方式和接收情况。其常见用例包括: - 对特定类型的数据包进行优先级排序。 - 丢弃特定类型的数据包。 - 带宽分配。 当需要在…

作者头像 李华
网站建设 2026/1/27 7:09:15

14、快速数据路径(XDP):原理、模式与应用指南

快速数据路径(XDP):原理、模式与应用指南 1. 快速数据路径(XDP)简介 快速数据路径(XDP)是 Linux 网络数据路径中一种安全、可编程且高性能的内核集成数据包处理器。当网络接口卡(NIC)驱动接收到数据包时,它会执行 Berkeley 数据包过滤器(BPF)程序。这使得 XDP 程…

作者头像 李华
网站建设 2026/1/27 22:48:02

3步搞定Snap.svg动画导出:从SVG到视频GIF的完整指南

3步搞定Snap.svg动画导出:从SVG到视频GIF的完整指南 【免费下载链接】Snap.svg The JavaScript library for modern SVG graphics. 项目地址: https://gitcode.com/gh_mirrors/sn/Snap.svg 你是否曾用Snap.svg创建了精美的动画效果,却苦于无法将其…

作者头像 李华
网站建设 2026/1/29 13:32:41

Java ArrayList扩容机制深度解析

这是一篇基关于 ArrayList 扩容机制的技术文章:深入解析 Java ArrayList 的动态扩容机制在 Java 集合框架中,ArrayList 因其高效的随机访问能力(时间复杂度为 $O(1)$)和动态调整大小的灵活性而广受欢迎。这种动态调整的核心在于其…

作者头像 李华
网站建设 2026/1/22 14:08:05

手把手教你Windows系统安装pgvector:PostgreSQL向量搜索实战指南

手把手教你Windows系统安装pgvector:PostgreSQL向量搜索实战指南 【免费下载链接】pgvector Open-source vector similarity search for Postgres 项目地址: https://gitcode.com/GitHub_Trending/pg/pgvector pgvector是PostgreSQL的开源向量相似性搜索扩展…

作者头像 李华
网站建设 2026/1/25 17:00:46

xtb量子化学计算终极实战指南:从新手到专家的完整路径

xtb量子化学计算终极实战指南:从新手到专家的完整路径 【免费下载链接】xtb Semiempirical Extended Tight-Binding Program Package 项目地址: https://gitcode.com/gh_mirrors/xt/xtb 在当今计算化学研究领域,xtb量子化学计算工具正以其卓越的计…

作者头像 李华