在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
一、Flex 布局简介 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。 任何一个容器都可以指定为 Flex 布局,也就是说,行内元素也可以设置成Flex 布局。 // 将块级元素div设置为flex布局 div { display: flex; } // 将行内元素span设置为flex布局 span { display: flex; } 采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器"。它的所有子元素自动成为容器成员,称为 Flex 项目(flex item),简称"项目"。 二、Flex布局的默认特性 默认情况下,容器中的所有子元素都将进行水平排列,类似于强制进行了一个左浮动,所以容器子元素的float和clear属性会失效。同时,容器中的子元素的对齐方式将不受vertical-align控制,即vertical-align也会失效。 <style> #main{ width:800px; height:300px; display:flex; font-size: 20px; background: red; } </style> <div id="main"> <div style="background-color:coral;" class="item-1">红色</div> <div style="background-color:lightblue;" class="item-2">蓝色</div> <div style="background-color:lightgreen;" class="item-3">带有更多内容的绿色啊</div> </div> ① 在没有给容器设置垂直方向对齐方式同时容器子元素也没有设置高度,那么容器子元素的高度是和容器的高度是一样的,如上,容器中所有的子元素的高度都会变为300px。 ② 默认情况下,容器下的子元素的宽度是不会自动放大的,即默认以元素自身的实际宽度显示。如图所示: ③ 默认情况下,容器下的子元素的宽度是可以缩小的,当容器中所有子元素的宽度之和超过了容器的宽度,默认不会换行显示,那么就需要缩小容器子元素的宽度以保证容器能够容纳下所有的子元素。但容器子元素的宽度并不是无限缩小的,即缩小到不能缩小为止。 .item-1 { width: 200px; } .item-2 { width: 8800px; } .item-3 { width: 8800px; } 比如上面,item2、item3宽度设置成了8800px,容器中所有子元素的宽度和为17800px,远远超出了容器的宽度800px,所以容器中的所有子元素必须按比例压缩,item1元素的宽度应变为200 - 191.01 = 8.99px,而item1最小被压缩为存放一个字所需要的宽度,即刚好等于字体的大小,即20px,所以item1的宽度将变为20px。 ④ 默认情况下,容器中的子元素可以被压缩到最小为止,但是当压缩到最小后仍然放不下所有的子元素,那么子元素就会被放到容器的外面。 ⑤ 如果给容器添加一个垂直方向的对齐方式,那么容器中所有子元素的高度将变为实际的高度,不会与容器等高。 #main{ width:800px; height:300px; display:flex; font-size: 20px; background: red; align-items: flex-start;/*添加垂直方向对齐方式*/ } 三、容器属性设置 容器默认存在两根轴:水平的主轴 和 垂直的交叉轴。主要就是设置容器的主轴方向、超过容器后是否换行显示、水平对齐方式、垂直对齐方式。 ① flex-direction : 用于设置主轴的方向,默认值为row,即容器中所有子元素水平排列。 column: 表示容器中所有子元素垂直排列。 row-reverse: 表示反转容器中所有子元素的顺序,并且起点靠右,即靠右对齐。 column-reverse: 表示反转容器中所有子元素的顺序,并且起点靠下,即靠容器底部对齐。 ② flex-wrap: 用于设置容器中子元素放不下的时候是否换行。默认值为nowrap,即不换行,即使放不下也不换行。 wrap : 表示可以换行,当设置为wrap可以换行的时候,容器中的元素就不会被压缩,而是采用换行显示。 #main { width:800px; height:300px; display:flex; background: red; flex-wrap: wrap; /*放不下的时候可以换行*/ font-size: 20px; } .item-1 { width: 300px; } .item-2 { width: 300px; } .item-3 { width: 300px; } wrap-reverse : 表示换行显示之后对行排列顺序进行反转。 wrap: wrap-reverse: ③ flex-flow: 是flex-direction 属性和flex-wrap属性的简写形式,默认值为row nowrap,即主轴为水平方向,不换行。 ④ justify-content: 用于设置主轴方向的对齐方式。 ⑤ align-items: 用于设置项目在交叉轴(非主轴)上对齐方式。 四、容器中元素(项目)属性设置 ① order: 用于设置容器元素的排列顺序,默认值为0,数值越小,排列越靠前。 .item-2 { order: -1; /*将item-2的order设置为-1,可以让item-2排在前面*/ } ② flex-grow: 用于设置容器元素的放大比例,默认值为0,即如果存在剩余空间,也不放大。 ③ flex-shrink: 用于设置容器元素的缩小比例,默认值为1,即如果空间不足,该项目将缩小。 ④ flex-basis: 用于设置容器元素占的大小,默认值为auto,即与容器元素的实际大小一致。进行缩放的时候会根据该值来进行计算是否有多余的缩放空间。 ⑤ flex: 是flex-grow、flex-shrink 、flex-basis的简写,默认值为0 1 auto,即不可放大、可缩小、大小与容器元素大小一致,后两个属性可选。 .item-2 { flex: 0 1 auto;/*注意三个值之间是空格二不是逗号*/ } ⑥ align-self: 用于单独设置某个容器元素的对齐方式,默认值为auto,表示继承父元素的对齐方式。 .item-2 { align-self: center;/*单独设置item-2居中对齐*/ } 五、felx:1 和flex: auto的区别 从上面可知,flex的默认值为 0 1 auto。flex的值比较灵活,可以设置很多种值,如: .item { flex: none; // 值为none } // 等价于 .item { flex-grow: 0; flex-shrink: 0; flex-basis: auto; } ② auto: 此时等于 1 1 auto。 .item { flex: auto; // 值为auto } // 等价于 .item { flex-grow: 1; flex-shrink: 1; flex-basis: auto; } ③ 一个非负数字: 此时这个非负数字指的是flex-grow的值,flex-shrink采用默认值1,但是flex-basis值为0%,如: .item { flex: 1; // 值为一个非负数字 } // 等价于 .item { flex-grow: 1; flex-shrink: 1; flex-basis: 0%; /*这里比较特殊为0%*/ } ④ 取值为两个非负数字: 此时分别代表的是flex-grow和flex-shrink的值,flex-basis取值为0%。 .item { flex: 6 8; // 值为两个非负数字 } // 等价于 .item { flex-grow: 6; flex-shrink: 8; flex-basis: 0%; /*这里比较特殊为0%*/ } ⑤ 一个长度或百分比: 此时这个值为flex-basis的值,flex-grow 取值为 1,flex-shrink 取值为 1 .item { flex: 200px; // 值为一个像素值 } // 等价于 .item { flex-grow: 1; flex-shrink: 1; flex-basis: 200px; } .item { flex: 100%; // 值为一个百分数 } // 等价于 .item { flex-grow: 1; flex-shrink: 1; flex-basis: 100%; } 需要注意的是,如果flex-basis设置为百分比,那么其相对的是容器的大小的百分比,而不是自身的大小的百分比。 从上可以看到,当flex的值为none或者auto或者不设置的时候,flex-basis的值才是auto;其他情况如flex的值为数字的时候,flex-basis的值则为0%。 所以flex: 1和flex: auto的区别就是,flex-basis的值不同,flex:1的时候flex-basis值为0%;flex: auto的时候,flex-basis的值为auto。 六、容器元素放大或缩小值计算 ① 放大的情况 #main{ width:800px; height:300px; display:flex; background: red; font-size: 20px; } .item-1 { width: 200px; flex: 2 1 auto; } .item-2 { width: 200px; flex: 3 1 10%;/*这里flex-basis值相当于是80px*/ } .item-3 { width: 100px; flex: 0 1 220px; } itme-1的flex-basis为auto,所以值和元素本身大小一致,即200px; ② 缩小的情况 #main{ width:800px; height:300px; display:flex; background: red; font-size: 20px; } .item-1 { width: 200px; flex: 0 2 auto; } .item-2 { width: 200px; flex: 0 3 100%;/*这里flex-basis值相当于是800px*/ } .item-3 { width: 100px; flex: 0 0 200px; } itme-1的flex-basis为auto,所以值和元素本身大小一致,即200px; 到此这篇关于浅谈Flex布局与缩放比例计算的文章就介绍到这了,更多相关Flex布局与缩放比例内容请搜索极客世界以前的文章或继续浏览下面的相关文章,希望大家以后多多支持极客世界! |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论