首页IT科技flex—direction(flex这些问题应该被理解)

flex—direction(flex这些问题应该被理解)

时间2025-05-04 19:59:25分类IT科技浏览4173
导读:flex三连问,帮助我们更好的理解布局利器 问题: flex的值 auto, none, 0, 1, initial分别是什么?有什么作用?有什么表现? flex-basis和width的...

flex三连问          ,帮助我们更好的理解布局利器

问题:

flex的值 auto, none, 0, 1, initial分别是什么?有什么作用?有什么表现? flex-basis和width的区别?单值flex-basis:0与auto的区别?flex-basis:100px与width:100px一样吗? 怎样理解剩余空间

解决:

问题一:

flex的值 auto, none, 0, 1, initial分别是什么?

flex: auto 为 1 1 auto

flex: none为 0 0 auto

flex: 0为 0 1 0

flex: 1为 1 1 0

flex: initial为 0 1 auto

提一嘴                ,我认为重要的是这个flex的默认值    ,也就是initial          。因为多数情况       ,我们都是在默认值上修改                 ,其他再不容易记的东西      ,也会有了参照而变得游刃有余                。

上述五种情况的作用及表现什么?

flex:initial(默认值)

父盒子设置为弹性盒    ,子元素默认就为initial                 ,一般用于还原默认值

表现为不会随之增大         ,会随之减小  ,宽度参照自身

flex:1

一般用于等分(分配剩余空间后                ,表现为等分)

表现为会随之增大            ,会随之减小,宽度内容区最小宽度(分配剩余空间前)

flex:0

不常用

表现为不会随之增大             ,会随之减小               ,宽度内容区最小宽度(分配剩余空间后)

flex:auto

一般用于文字越长  ,元素越宽的场景

表现为会随之增大          ,会随之减小                ,宽度参照自身

flex:none

一般用于保持元素自身宽度    ,且文字不换行

表现为不会随之增大       ,不会随之减小                 ,宽度参照自身

问题二:

flex-basis和width的区别?单值flex-basis:0与auto的区别?

两者都是用于改变弹性盒元素的宽度

flex-basis比width优先级更高;

如果flex-basis为auto      ,那么元素就会参照width

如果flex-basis不为auto(如:0    ,200px等)                 ,那么元素就会忽略width(即使你设置了width)         ,采用flex-basis的值

flex-basis:100px与width:100px(弹性盒可缩减为前提条件)一样吗?

首先说结论  ,不一样!!!

width:100px + flex-basis:auto === 元素100px content + flex-basis:100px === max(content                , flex-basis:100px) >= 元素100px

剖析一下            ,有以下两种情况:

元素flex-basis为auto时,width设为100px             ,那么当缩小弹性盒时               ,元素始终为100px  ,不会变化    。那么如果该元素内容区宽度超过100px(比如内嵌的图片          ,font-size大小等)                ,那么也不会撑大该元素    ,它就是个定值100px

元素flex-basis不为auto时       ,width设为多少都没用                 ,优先取flex-basis的值       。若flex-basis为100px      ,那么如果该元素内容区宽度超过100px(比如内嵌的图片    ,font-size大小等)                 ,那么与设置width结果相反         ,会撑大该元素  ,最后计算的宽度会大于100px                 。

width就是写死                ,无论怎么变            ,该元素就是这么宽;flex-basis意思是,元素大概是这么宽             ,如果有意外情况               ,那么我还会改变      。

举个小栗子帮助理解下:你晚上在加班  ,女朋友要让你陪她一个小时          ,但是女人的嘴                ,骗人的鬼    ,指不定耽误多长时间呢    。然后                 。         。  。

width的理解:我是个负责任的男人       ,一个小时一分不多一分不少                 ,不会因为任何说法改变这一个小时                。

flex-basis的理解:女朋友比任何事都重要      ,如果她不闹腾    ,那么一个小时就准时结束                 ,否则         ,我只能由着她的性子来了            。唉  ,折腾到明早也有可能                ,没办法            ,谁让她最重要呢?

问题三:

怎样理解剩余空间?

开启弹性盒的元素的宽度为总空间

去掉所有子元素的固定宽度后,剩余的空间就叫做剩余空间

子元素有width属性             ,那么去掉width就是剩余空间

子元素有flex-basis:100px

如果100px小于总宽度               ,那么去掉flex-basis就是剩余空间

如果100px大于总宽度  ,那么没有剩余空间

如果缩减系数flex-shrink为0          ,那么元素就是100px                ,表现为超出父盒子

如果缩减系数flex-shrink不为0    ,元素的最终宽度也要少于100px

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
一刀999游戏怎么卸载(一刀9999亿怎么彻底卸载) React事件处理过程中传参的实现方法