首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

CSS flex笔记

在弹性布局模型中,弹性容器的子元素可以在任何方向上排布,也可以“弹性伸缩”其尺寸,既可以增加尺寸以填满使用的空间,也可以收缩尺寸以避免父元素溢出。子元素的水平对齐和垂直对齐都能很方便的进行操控。...Container Style 容器样式: flex可以提供block和inline两种对外效果。但是并不影响内部元素。因为内部元素会被设定为flex项目。...space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。...flex-end:交叉轴的终点对齐。 center:交叉轴的中点对齐。 baseline: 项目的第一行文字的基线对齐。...收缩系数 类似于flex-grow,但是shrink系数只在容器宽度不够全部元素默认宽度的时候才会发生 数字越大,收缩的时候越明显 https://developer.mozilla.org

77420

「译」Flexbox 基本原理

flex-wrap 的默认值为 nowrap,这意味着如果容器不能在保留项目原始宽度的同时将它们排列成一行的话,项目将会收缩以进行适应。如果由于某些原因无法收缩,则项目会溢出容器外 [1][3]。...flex-grow:如果有额外空间,每个项目应该如何伸展 flex-shrink:如果空间不足,每个项目应该如何收缩 flex-basis:在设置以上两个属性之前项目的大小 flex-grow 该属性设置的是弹性增长系数...下图中,每个项目以自身内容值作为弹性收缩比率。 ? flex-basis flex-basis 属性会在实际设置可用空间之前检查每个项目应该具有的大小。...如果没有足够的空间,由于 flex-shrink 默认为 1,所有的项目会均匀地收缩。如果有剩余的空间,由于 flex-grow 默认为 0,剩余空间会放置在最后一个项目的后面。 ?...:使项目失去弹性,与 flex: 0 0 auto 效果一样 flex: 1:弹性项目可以伸展/收缩,并且 flex-basis 设置为 0 ,与 flex: 1 1 0 效果一样 Autoprefixer

1.9K30
您找到你想要的搜索结果了吗?
是的
没有找到

CSS 基础系列:flex 布局

flex-shrink 属性定义了父容器空间不足时子项目如何收缩以适应有限的空间 该属性与 flex-grow 相对,不同的是其值的计算还与自身宽度有关。...那么这 -150px 将由三个元素的分别收缩一定的量来弥补。 具体的计算方式为:每个元素收缩的权重为其 flex-shrink 乘以其宽度。...200 - 41.4 = 158.6 300 - 93.1 = 206.9 同样,当所有元素的 flex-shrink 之和小于 1 时,计算方式也会有所不同: 此时,并不会收缩所有的空间,而只会收缩...三个元素收缩总和并不是 150px,而是只会收缩 150px 的 (0.1 + 0.2 + 0.3) / 1 即 60% 的空间:90px。...每个元素收缩的空间为: 90 0.1(flex-shrink) 150(width) / 145 = 9.31 90 0.2(flex-shrink) 200(width) / 145 = 24.83

1.5K10

CSS中Flex布局的可伸缩性(Flexibility)

一个伸缩容器会等比地按照各伸缩项目的 扩展比率 分配剩余空间,也会按照 收缩比率 缩小各项目以避免溢出。 ? Flex属性 flex属性可用来指定 可伸缩长度 的部件:扩展比率,收缩比率,伸缩基准线。...当有一个元素是伸项目时,flex属性将代替主轴长度属性决定元素的主轴长度。若元素不是伸缩项目,则flex属性不生效。...取值为 ,用来指定项目收缩比率;若在flex缩写省略了此属性值,则flex-shrink的指定值是 1; 取值为 <length...(如果项目的主尺寸为auto,则会以其内容大小为基准) 当剩余空间为正值时,伸缩项目无法伸缩,但当空间不足时,伸缩项目收缩至其[最小]值。...默认状态下,伸缩项目不会收缩至比其最小内容尺寸更小。 可以通过设置「min-width」或「min-height」属性来改变这个默认状态。

1.5K30

CSS3的flex布局

flex的一些属性 CSS3中引入了另一种框--flexbox,flexbox有一些block和inline不同的性质,比如: 自适应子元素(flex item,又称伸缩项目)的宽度 伸缩项目的float...若flex-wrap:wrap,则换行放置,若为flex-wrap:nowrap,则所有伸缩项目放在同一行内。          ...flex-grow属性值为正数值,用来设置扩展比率,也就是剩余空间是正值的时候此伸缩项目相对于伸缩容器里其他伸缩项目能分配到空间比例。若省略则会被设置为“1”。...flex-shrink属性值为正数值,用来设置收缩比率,也就是剩余空间是负值的时候此伸缩项目相对于伸缩容器里其他伸缩项目收缩的空间比例。...若省略则会被设置为“1”,在收缩的时候收缩比率会以伸缩基准值加权。

1.4K60

flexbox布局指南

收缩因子) P.S.如果要让元素不可伸缩,让拉伸因子和收缩因子都为0即可(flex-grow: 0; flex-shrink: 0,或者简写属性flex: none等价于flex: 0 0 auto)...: 0,其效果就是把300px都当做额外空间,并按1:1:1分配 flex-shrink 收缩因子,伸缩行装不下该行内容时依据flex-shrink与基础尺寸(见下文布局算法部分)确定各项将收缩空间的比例...: 收缩比例 = 当前项的flex-shrink值 * 基础尺寸 / 当前行所有项的(flex-shrink值 * 基础尺寸)之和 收缩的情况相对麻烦一些,涉及概念较多,具体示例见下文布局算法部分 flex...|| ] 简写属性,默认flex: 0 1 auto(默认各项按内容尺寸比例收缩,不拉伸)。...div> 关键点在于文本flex-shrink缩回来,这样在文本溢出时能够收缩回来,给icon留出足够的空间,溢出时,收缩不影响文本宽度,右侧icon就能够紧贴着 另外,第二行容器的max-width

1K40

弹性布局flex-grow和flex-shrink

,比如icon、图片等,如果设为0,则会出现超出截断的问题 flex-basis :定义了在分配多余空间之前,项目占据的主轴空间(main size)。...它的默认值为auto,即项目的本来大小 flex属性:flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。...: nowrap; word-wrap: break-word; word-break: break-all; /* 弹性布局,空间有剩余,允许占用剩余空间,如果要收缩...,也可以收缩,因为会切换为两行,auto则代表宽度始终为实际宽度*/ flex: 1 1 auto; } /*右侧icon和标识文字盒子*/ .right{ /*弹性布局...,icon及其他标识文案,宽度不固定,则flex-basis:auto,始终为实际宽度,但是不能被截断,也不要占用多余的空间,多余的给文字使用,即不允许占用多余空间,也不允许收缩*/ flex

1.1K20

CSS 中的 Flex 布局 完全指南

使用display: flex;创建,flex 是一个 CSS 的display属性中新添加一个值,而容器下的每个子元素将成为 flex item(伸缩项目)。...我们用 justify 属性控制主轴项目的空隙,使用 align 属性控制交叉轴项目之间的垂直行为。...flex-grow 定义弹性盒子项(flex item)的拉伸因子,将相对于同一行上所有其他项目的大小总和进行缩放,这些项目将根据指定的值自动调整。它的值是number,负数无效。...flex-shrink 指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。...flex 它是flex-grow, flex-shrink和flex-basis的简写,默认值为0 1 auto。后两个属性可选。 order 用来重新排列项目的自然顺序。

1.5K20

深入 CSS 中的弹性盒子 Flexible Box

弹性容器扩展其内元素来填充可用空间,或将其收缩来避免溢出。 2. 相关术语 ? 弹性容器Flex container 指的是包含着弹性项目的父元素。...通过设置 display 属性的值为 flex 或 inline-flex 来定义弹性容器。 弹性项目Flex item 弹性容器的每个子元素都称为弹性项目。...flex-flow 属性是 flex-direction 和 flex-wrap 属性的简写,决定弹性项目如何排布。...&editable=true] 6. flex-shrink:收缩比例 [ʃrɪŋk] flex-shrink 属性指定了 flex 元素的收缩规则,初始值为1,类型,负值无效。...flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。 ? 演示地址[https://codepen.io/anon/pen/MdvymX?

1.1K40

微信小程序布局

: number|initial|inherit; flex-wrap: nowrap|wrap|wrap-reverse|initial|inherit; flex-directions属性规定灵活的项目方向...flex-wrap 属性规定灵活项目是否拆行或拆列。nowrap规定灵活的项目不拆行或不拆列。wrap规定灵活的项目在必要的时候拆行或拆列。...flex-basis 属性用于设置或检索弹性盒伸缩基准值(宽度值),number 一个长度单位或者一个百分比,规定灵活项目的初始长度。auto自动撑开,根据内容决定。...number一个数字,规定项目将相对于其他灵活的项目进行扩展的量。默认值是 0。 flex-shrink 属性指定了 flex 元素的收缩规则。...flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。

1.3K60

css面试点四:css3弹性盒子模型-flex布局详解

所以,容器必须设置flex-wrap:···; 项目的属性:设置在项目上的属性也有6个。...若所有项目flex-grow的数值都相同,则等分剩余空间 若果有一个项目flex-grow为2,其余都为1,则该项目占据剩余空间是其余的2倍 flex-shrink属性:定义项目的缩小比例 默认值都为...如果有一个项目的值为0,其他项目为1,当空间不足时,该项目不缩小。 负值对该属性无效,容器不应该设置flex-wrap。...flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。 如果所有项目都为0,则当空间不足时,项目撑破容器而溢出。...注意设置的flex-basis是分配多余空间之前项目占据的主轴空间,如果空间不足则默认情况下该项目也会缩小。

1.3K20

Flex弹性布局

wrap-reverse同样表示换行,需要注意的是第一排会紧贴容器底部,而不是我们想象的项目6紧贴容器顶部,效果与wrap相反 flex-flow属性 flex-flow属性是flex-deriction...所以,项目之间的间隔比项目与边框的间隔大一倍。 align-items属性 align-items属性定义项目在交叉轴上如何对齐。 flex-start:交叉轴的起点对齐。...假设默认三个项目中前两个个项目都是0,最后一个是1,最后的项目会沾满剩余所有空间。 假设只有第一个项目默认为0,后面两个项目flex-grow均为1,那么后两个项目平分剩余空间。...flex-shrink flex-shrink 属性规定某个 flex 项目相对于其余 flex 项目收缩多少。...: 3; } 使第二个弹性项目相比其余项目收缩三倍。

1.5K10

玩转 CSS Flexbox 弹性布局

创建 flex 容器 2. 主轴方向与多行容器 3. 主轴项目对齐方式 4. 交叉轴项目对齐方式 5. 多行容器项目对齐方式 6. 单个项目在交叉轴上的的对齐方式 7. 单个项目的排列顺序 8....主轴项目对齐方式 ---- 只有一个属性: justify-content,常用属性值如下表 属性值 描述 flex-start 所有项目与主轴起始线对齐【默认值】 flex-end 所有项目与主轴终止线对齐...交叉轴项目对齐方式 ---- 只有一个属性: align-items,常用属性值如下表 属性值 描述 flex-start 所有项目与交叉轴起始线对齐【默认值】 flex-end 所有项目与交叉轴终止线对齐...第一个值:整数 flex-grow 第二个值:整数 flex-shrink 第三个值:有效宽度 flex-basis 举例 案例 描述 flex: 0 1 auto; 不放大,可收缩,初始宽度【默认值...】 flex: 1 1 auto; 项目自动放大或收缩适应容器 flex: 0 0 100px; 按计算大小填充到容器中 双值语法: 属性值 描述 第一个值:整数 flex-grow 第二个值:有效宽度

91810

Flex Box布局学习- 语法

它的所有子元素自动成为容器成员,称为Flex项目flex item),简称"子元素"。 !...* stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。 ### 4. flex-wrap属性 默认情况下,项目都排在一条线(又称"轴线")上。...imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) #### 2. flex-shrink属性 flex-shrink属性表示一个子元素在必要时是否收缩自己来适应当前的...flex-shrink.png 容器宽度:200 弹性子元素宽度:100 收缩比例为:2:1:1 所以:1003-200=100,超出100,按比例划分,就是item1被移除溢出量=100/(2+1+1...eg2: 如果其中有一个元素设置了flex-shrink: 0;则其宽度不会收缩,其他部分按比例收缩即可。

77430

从零开始学 Web 之 CSS3(七)多列布局,伸缩布局

它的两种取值: 2.1、flex-wrap flex-wrap: 控制子元素是否换行显示,默认不换行 nowrap:不换行--则收缩 wrap:换行 wrap-reverse:翻转,原来是从上到下,...相反,flex-grow 设置的是父盒子剩余空间的比例分配,而 flex-shrink 设置的是,如果父盒子宽度不够时,子元素的收缩比例。...flex-shrink 默认值为1。 如果将 flex-shrink 的值设置为 0 的话,父盒子宽度不够时,子元素不收缩,会溢出。...flex: [number]:这个语法指定了一个数字,代表了这个伸缩项目该占用的剩余空间比例。...flex: auto:属性值被设为auto的伸缩项目,会根据主轴自动伸缩以占用所有剩余空间 3.4、flex 应用案例 需求:不管有多少个 li 标签,总是能平分父盒子(因为从服务器获取的 li 标签的个数可能不是固定的

4K10

【Taro】363- 玩转 Taro 跨端之 flex 布局篇

Flexbox 的关键特性是 flex 布局中的项目可以增长和缩小。可以将空间分配给项目本身,或者在项目之间或周围分配空间。...语法格式 | inherit 负值无效 React Native 上默认值为 0 flex-shrink flex-shrink 属性指定了 flex 元素的收缩规则。...flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。默认值为 1。 语法格式 | inherit 负值是不被允许的。...React Native 上使用 ScrollView 组件会导致属性失效 如果没有足够空间,组件不会发生收缩 (应该是设置了 flex-shrink 属性值默认为 0) flex flex 规定了 flex...当 flex = -1 时,组件通常根据 width 和 height 确定大小。但是,如果没有足够的空间,组件将收缩到 minWidth 和 minHeight。

3.3K30

CSS Flexbox 可视化手册

如果这些项目的高度不一致,它们将会伸展到最高的那个高度 flex-basis默认为 auto(项目宽度将由其内容决定) flex-wrap默认为nowrap(如果容器的宽度不足以适合这些项目,它们不会换行...在默认情况下,flex-wrap被设置为 nowrap,这意味着如果容器不能适应在其内的行中原始宽度的项目,则这些项目将会缩小来进行适应。 如果它们因为某种原因无法收缩,则会溢出容器。...flex-grow:如果有额外的空间,每个项目应该如何放大 flex-shrink:如果没有足够的空间,应该如何缩小每个项目 flex-basis:在设置上述两个属性之前,该项目的大小应该是多少 flex-grow...由于没有空间容纳所需的总宽度 1500px,所以默认的flex shrink factor(弹性收缩系数)的值为1,这样会使每个项目的宽度均匀缩小到196px。 ?...这告诉浏览器:如果在理想状态下,有足够的空间来放置所有的项目,就遵循它们的160px宽度,并且没有正/负可用空间;如果没有足够的空间的话,那么 flex-shrink默认为1,所有项目均匀收缩; 如果有额外的空间

3K20

TitleCSS Flex布局完全指南

),.container的直接子元素被称为Flex项目(Flex item) Flex元素按照主轴(main-axis)的方向排列,交叉轴(cross-axis)与主轴垂直 主轴的开始和结束被称为 main...指定项目在主轴(main-axis)上的对齐方式 align-items flex-start,flex-end,center,baseline,stretch 指定项目在交叉轴(cross-axis...(如果项目只有一根轴线.该属性不起作用) Tag/项目(flex item)属性 属性 可取值 说明 order 指定项目的排列顺序,默认值为0,order...相同时按照项目在DOM中的顺序排序 flex-grow 指定项目大小的比例,默认值为0,width属性会优先指定flex-item的最小大小 flex-shrink... 指定项目大小在单行空间不足时的收缩比例,默认值为1 flex-basis 指定项目在主轴方向上的初始大小 flex <'flex-grow

34100
领券