MDN之Web 开发技术【flex】

今天药忘吃喽~ 2021-07-04 21:15 540阅读 0赞

CSS属性 flex 规定了弹性元素如何伸长或缩短以适应flex容器中的可用空间。这是一个简写属性,用来设置 flex-grow, flex-shrinkflex-basis

大多数情况下,开发者需要将 flex 设置为 auto,initial,none,或一个无单位正数。尝试调整下面的 flex 容器以观察这些值的作用:
在这里插入图片描述
默认情况下,元素不会缩短至小于内容框尺寸,若想改变这一状况,请设置元素的min-widthmin-height属性。

语法

  1. /* Basic values */
  2. flex: auto;
  3. flex: initial;
  4. flex: none;
  5. flex: 2;
  6. /* One value, unitless number: flex-grow */
  7. flex: 2;
  8. /* One value, width/height: flex-basis */
  9. flex: 10em;
  10. flex: 30px;
  11. /* Two values: flex-grow | flex-basis */
  12. flex: 1 30px;
  13. /* Two values: flex-grow | flex-shrink */
  14. flex: 2 2;
  15. /* Three values: flex-grow | flex-shrink | flex-basis */
  16. flex: 2 2 10%;
  17. /* Global values */
  18. flex: inherit;
  19. flex: initial;
  20. flex: unset;

flex 属性可以指定1个,2个或3个值。

单值语法: 值必须为以下其中之一:

  • 一个无单位数(<number>): 它会被当作<flex-grow>的值。
  • 一个有效的宽度(width)值: 它会被当作 <flex-basis>的值。
  • 关键字noneautoinitial.

双值语法: 第一个值必须为一个无单位数,并且它会被当作 <flex-grow> 的值。第二个值必须为以下之一:

  • 一个无单位数:它会被当作 <flex-shrink> 的值。
  • 一个有效的宽度值: 它会被当作 <flex-basis> 的值。

三值语法:

  • 第一个值必须为一个无单位数,并且它会被当作 <flex-grow> 的值。
  • 第二个值必须为一个无单位数,并且它会被当作 <flex-shrink> 的值。
  • 第三个值必须为一个有效的宽度值, 并且它会被当作 <flex-basis> 的值。

取值

initial

元素会根据自身宽高设置尺寸。它会缩短自身以适应 flex 容器,但不会伸长并吸收 flex 容器中的额外自由空间来适应 flex 容器 。相当于将属性设置为”flex: 0 1 auto“。

auto

元素会根据自身的宽度与高度来确定尺寸,但是会伸长并吸收 flex 容器中额外的自由空间,也会缩短自身来适应 flex 容器。这相当于将属性设置为 “flex: 1 1 auto”.

none

元素会根据自身宽高来设置尺寸。它是完全非弹性的:既不会缩短,也不会伸长来适应 flex 容器。相当于将属性设置为”flex: 0 0 auto“。

<'flex-grow'>

定义 flex 元素的 flex-grow 属性,详见 。默认值为 0,负值无效。

<'flex-shrink'>

定义 flex 元素的 flex-shrink 属性,详见 。默认值为1,负值无效。

<'flex-basis'>

定义 flex 元素的 flex-basis 属性。若值为0,则必须加上单位,以免被视作伸缩性。 默认值为 auto
当使用一个或两个无单位数时, flex-basis会从auto变为0. 可以参考 Flexible Box Layout Module 草案来了解更多信息。

正式语法

  1. none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]

示例

  1. #flex-container {
  2. display: flex;
  3. flex-direction: row;
  4. }
  5. #flex-container > .flex-item {
  6. flex: auto;
  7. }
  8. #flex-container > .raw-item {
  9. width: 5rem;
  10. }
  11. <div id="flex-container">
  12. <div class="flex-item" id="flex">Flex box (click to toggle raw box)</div>
  13. <div class="raw-item" id="raw">Raw box</div>
  14. </div>

Result

在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,540人围观)

还没有评论,来说两句吧...

相关阅读