如何理解flex: 1 1 50%

在CSS Flexbox布局中,flex: 1 1 50%flex-growflex-shrinkflex-basis 三个属性的简写形式。以下是详细解释:

分解属性:

  1. flex-grow: 1

    • 当容器有剩余空间时,该项目会按比例放大。
    • 所有项目的 flex-grow 值总和为分母,当前项目的值作为分子分配空间。
    • 例如:两个项目均为 flex-grow:1,则各占剩余空间的 1/2。
  2. flex-shrink: 1

    • 当容器空间不足时,该项目会按比例缩小。
    • 缩小比例计算方式与 flex-grow 类似(考虑基础尺寸)。
  3. flex-basis: 50%

    • 定义项目的初始尺寸(主轴方向)。
    • 50% 表示初始宽度为父容器宽度的 50%(水平布局时)。

行为特点:

  • 基础尺寸 :项目初始占父容器宽度的 50%
  • 空间充足时 (如父容器宽度为 1000px):
    • 两个项目:各占 500px(总和 100%,无剩余空间,flex-grow 不生效)。
    • 单个项目:占 500px,剩余 500pxflex-grow:1 分配给它(最终占满容器)。
  • 空间不足时 (如父容器宽 800px,两个项目初始总宽 1000px):
    • 超出 200pxflex-shrink:1 等比例收缩(每个项目缩小 100px,最终各占 400px)。

示例场景:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Flexbox 布局示例</title>
    <style>
        .outer-box {
            width: 1000px;  /* 父容器宽度 */
            height: 400px;
            border: 1px solid #000000;
            display: flex; /* 父容器,使用 Flexbox 布局 */
        }
        .inner-box {
            flex: 1 1 50%; /* 简写属性 */
        }
        .inner-box1 {
            background-color: red;
        }
        .inner-box2 {
            background-color: blue;
        }
    </style>
</head>
<body>
    <div class="outer-box">
        <div class="inner-box inner-box1"></div>
        <div class="inner-box inner-box2"></div>
    </div>
</body>
</html>
  • 结果 :两个项目各占 500px(初始 50% 正好填满容器,无放大/缩小)。

关键点总结:

属性 作用
flex-grow 1 有剩余空间时,按比例放大
flex-shrink 1 空间不足时,按比例缩小
flex-basis 50% 初始尺寸为父容器宽度的 50%

此设定适合需要响应式伸缩的场景,项目既能保持基础占比,又能动态适应容器变化。

相关推荐
白兰地空瓶13 分钟前
用 Stylus 写 CSS 有多爽?从响应式面板案例看透它的优雅
css·stylus
佛系菜狗34 分钟前
防抖和节流-防抖鸿蒙版本实现
前端
不一样的少年_1 小时前
老板问我:AI真能一键画广州旅游路线图?我用 MCP 现场开图
前端·人工智能·后端
东方石匠1 小时前
Javascript常见面试题
前端·javascript·面试
恋猫de小郭1 小时前
Flutter 也有类 React Flow 的节点流程编辑器,快来了解下刚刚开源的 vyuh_node_flow
android·前端·flutter
性野喜悲1 小时前
<script setup lang=“ts“>+uniapp实现轮播(swiper)效果
前端·javascript·vue.js·小程序·uni-app
wangdaoyin20101 小时前
UniApp 在手机端(Android)打开选择文件和文件写入
android·前端·uni-app
用户497357337981 小时前
高端Web全栈工程师精品就业实战班课程 从零打造Web架构师
前端
我们没有完整的家1 小时前
技术速递|Playwright MCP 调试 Web 应用时,GitHub Copilot 生成断言脚本的实用方法
前端·github·copilot
universe_011 小时前
前端学习之八股和算法
前端·学习