5分钟掌握FlexItem布局

属性点梳理

按照国际惯例,真正理解属性之前,我们首先需要知道项目存在哪些知识点。

> 容器内部项目属性  

1):order

容器内子项目的前后排列顺序。

2):flex-grow

规定容器内项目尺寸放大的比例。

3):flex-shrink

规定容器内项目尺寸缩小的比例。

4):flex-basis

该属性用于设置或检索弹性盒伸缩基准值。

5):flex
flex-grow、flex-shrink、flex-basis三个属性的集合,类似于margin这样的集合属性。
6):align-self
该属性定义flex子项单独在侧轴(纵轴)方向上的对齐方式。

这些定义如果现在看不懂也不要紧,接下来的部分我将以图文的方式详细得来展现各个属性的效果。

记忆和理解

好消息是这一块的属性,会涉及一些数学上的计算,那么1就是1,2就是2,会有助于我们进行理解。

order项目前后顺序

order属性只接受整数属性值。越小item项目排列顺序越靠前。

order

flex-grow项目尺寸放大比例

该属性只支持int数值,默认值为1,0和负数将不起作用。
单位1剩余空间:(容器主轴方向尺寸-(所有item项目的尺寸和))/(所有item项目flex-grow相加的值)
那么在浏览器计算完成后,设置了该属性的item项目尺寸将会变成,初始尺寸值+单位1剩余空间值*本item的flex-grow值。要是想清楚的看到效果,尽量不要设置尺寸为auto。

flex-grow

分析上图案例:外层容器宽度350px,每一个文档流项目宽度为100px,所以,那么第一行多出来350-300=50px,那么第一行单位1宽度为12.5px=50/(1+2+1),所以文档流1号宽度将变成112.5px,2号将变成125px。那么分行也是这么进行计算。

flex-shrink项目尺寸缩小比例

类似于flex-grow属性,单位1缩减空间计算值:(所有item项目尺寸和-容器尺寸)/(全部item flex-shrink 值的和)。

flex-shrink

案例分析:flex容器主轴方向为水平左到右,宽度为200px,文档流项目宽度都为200px,单位1缩小尺寸=400/(1+2+4)=57.14px,那么就会产生一个问题:3号项目应该要缩小57.14*4=228.57px,这个时候如果3号项目没有内容,那么将不会进行展示,但是这个时候有内容,就撑起内容的宽度,导致出现计算上的偏差。

我的建议是:要想出现完美的缩小样式,还希望不要把容器的主轴尺寸设置的太小,并且也不要把项目的flex-shrink设置的太大,一旦缩小值比项目自身的尺寸还要大,要么就不会进行展示,要么就按照内部内容进行支撑。

flex-basis项目伸缩基准值

渲染项目主轴方向的尺寸之前,浏览器率先查看项目里面的basis属性的值。
那么我们就盘点该属性都有哪些可能的取值。

*1:auto
这个时候浏览器在计算布局的时候,先查看width或者是height,这个取决于主轴(flex-direction),是否有放大缩小的情况就取决于grow和shrink的属性设置。

2:非负数百分比
项目的尺寸的计算已经和本身的宽度和高度无关,那么初始尺寸就是flex容器尺寸
flex-basis。

*3:非负数像素尺寸
项目的尺寸初始值就是basis的值,然后在判断是否需要伸缩尺寸。

align-self 特立独行

该属性覆盖了父容器中的align-items属性值,一个不服从管教的孩子,大家都坐在一排,他却偏要做到教师最后一排,就是这么有个性。
既然是自己给自己下命令,那么可能存在的属性值就和align-items属性相同。

总结

本篇介绍了item项目上的flex弹性盒子的属性,东西不是很多,学习要点就是写布局之前需要在脑海中多进行建模,和计算,不用很精细的去计算,只要达到效果就行,只要在误差内就是一种可行的方式。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容