解密Flex布局:为什么flex:1仍会导致内容溢出

前言

今天在解决别的bug时发现了个很奇怪的东西,我的容器明明设置了flex:1为什么还会导致内容溢出,导致比我设想的flex:1尺寸来得大。

后来才知道

浏览器默认为flex容器的子元素设置了 min-width: auto;min-height: auto,这意味着子元素的最小宽度和高度不能小于其内容的宽度和高度。

这就是为什么明明是flex:1,但是为什么比预想的要大了。

正文

单单文字说明还是难以理解,来看图和代码吧

有问题的代码,父元素设置100vw,子元素设置flex:1;

tsx 复制代码
function App() {
  return (
    <div
      style={{
        display: "flex",
        height: "100vh",
        width: "100vw",
        gap: "10px",
      }}
    >
      <div
        style={{
          width: "200px",
          textAlign: "left",
          backgroundColor: "red",
        }}
      >
        Left
      </div>
      <div
        style={{
          flex: 1,
          textAlign: "left",
          backgroundColor: "blue",
        }}
      >
        <section
          style={{
            height: "100%",
            width: "100%",
            overflow: "auto",
            backgroundColor: "lightcyan",
          }}
        >
          <div>
            <div>asdasd</div>
            <div>
              asdasdasdasdasdsadsadasdsadasdiuoasdgiasgdfasghdiopasdyiuskafdgiuashdasgvdsadpjnasildgsaodiasoudgasiugdasyfdgasudiyfasdhoiashdgiouasgdiu
            </div>
            <div>asdasd</div>
          </div>
        </section>
      </div>
    </div>
  );
}

预计是滚动条只在右边区域,总页面没有滚动条。但是实际的总页面有滚动条,右边区域没有滚动条。这就是 浏览器默认为flex容器的子元素设置了 min-width: auto;min-height: auto,这意味着子元素的最小宽度和高度不能小于其内容的宽度和高度,把右侧的内容撑大了,导致内容溢出了。

如何解决呢

  1. 设置 overflow,利用BFC
  2. 设置 min-width: 0

任意使用一种都可以,是我们预计的情况了。

修改后代码

tsx 复制代码
function App() {
  return (
    <div
      style={{
        display: "flex",
        height: "100vh",
        width: "100vw",
        gap: "10px",
      }}
    >
      <div
        style={{
          width: "200px",
          textAlign: "left",
          backgroundColor: "red",
        }}
      >
        Left
      </div>
      <div
        style={{
          flex: 1,
          textAlign: "left",
          backgroundColor: "blue",
          minWidth: 0, //关键
        }}
      >
        <section
          style={{
            height: "100%",
            width: "100%",
            overflow: "auto",
            backgroundColor: "lightcyan",
          }}
        >
          <div>
            <div>asdasd</div>
            <div>
              asdasdasdasdasdsadsadasdsadasdiuoasdgiasgdfasghdiopasdyiuskafdgiuashdasgvdsadpjnasildgsaodiasoudgasiugdasyfdgasudiyfasdhoiashdgiouasgdiu
            </div>
            <div>asdasd</div>
          </div>
        </section>
      </div>
    </div>
  );
}

结语

有兴趣的可以去试试

相关推荐
农夫山泉不太甜31 分钟前
Tauri v2 实战代码示例
前端
yuhaiqiang1 小时前
被 AI 忽悠后,开始怀念搜索引擎了?
前端·后端·面试
红色石头本尊1 小时前
1-umi-前端工程化搭建
前端
真夜1 小时前
关于对echart盒子设置百分比读取的宽高没有撑开盒子解决方案
前端
楠木6851 小时前
RAG 资料库 Demo 完整开发流程
前端·ai编程
肠胃炎2 小时前
挂载方式部署项目
服务器·前端·nginx
像我这样帅的人丶你还2 小时前
使用 Next.js + Prisma + MySQL 开发全栈项目
前端
FPGA小迷弟2 小时前
FPGA 时序约束基础:从时钟定义到输入输出延迟的完整设置
前端·学习·fpga开发·verilog·fpga
毛骗导演2 小时前
@tencent-weixin/openclaw-weixin 插件深度解析(四):API 协议与数据流设计
前端·架构
毛骗导演2 小时前
@tencent-weixin/openclaw-weixin 插件深度解析(二):消息处理系统架构
前端·架构