css弹性盒

一,怪异盒模型

       box-sizing用来设置盒模型的解析规则的

       box-sizing 属性允许您以特定的方式定义匹配某个区域的特定元素。

        content-box(按标准盒模型的规则解析)这是由CSS2.1 规定的宽度高度行为。

                   宽度和高度分别应用到元素的内容框。

                   在宽度和高度之外绘制元素的内边距和边框。

         border-box(按怪异盒模型的规则解析)为元素设定的宽度和高度决定了元素的边框盒。

                     就是说,为元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制。

                     通过从已设定的宽度和高度分别减去边框和内边距才能得到内容的宽度和高度。

二,弹性盒模型

     1,概念

           Flex是Flexible Box的缩写,意为“弹性布局”,用来为盒模型提供最大的灵活性

         a, 设置弹性盒(父元素添加)

             display:flex/inline-flex     属性值: flex:将对象作为弹性伸缩盒显示 

                                                                 inline-flex:将对象作为内联块级弹性伸缩盒显示

         b,主轴排列方向 (顺序指定了弹性元素在父容器中的位置

              flex-direction   属性值:row   默认横向一行内排列

                                                      row-reverse   反向横向排列(右对齐 从后往前排

,最后一排在最前面)                  column    纵向排列

                                                      column-reverse    反转纵向排列,从下往上排,最后—项排在最上面

             c, justify-content(主轴对齐方式)(内容对齐(justify-content)属性应用在弹性容器上,控制伸缩项目在伸缩容器中的主轴(main axis)对齐方式)

                   justify-content   属性值 flex-start默认值,主轴顶端对齐

                                                          flex-end主轴末端对齐

                                                          center主轴居中对齐

                                                          space-between在主轴两端对齐,中间自动分配

                                                          space-around在主轴自动分配空白空间

                                                          space-evenly平均分配空白空间   

   d,align-items(侧轴对齐方式)(侧轴对齐方式:控制伸缩项目在伸缩容器中的侧轴对齐方式)

        align-items          属性值    flex-start:弹性盒子元素在伸缩容器里延侧轴顶端对齐。

                                                    flex-end:弹性盒子元素在伸缩容器里延侧轴未端对齐。

                                                   center:弹性盒子元素在伸缩容器里延侧轴居中对齐。

                                                   baseline:弹性盒子元素在伸缩容器里延侧轴基线对齐。

                                                    stretch:默认值。项目未设置侧轴的尺寸时拉伸成容器的侧轴尺寸。

          e,flex-wrap该属性控制伸缩容器当内容超出容器的尺寸时是否换行,同时侧轴的方向决定了新行堆叠的方向。

             flex-wrap 属性值:nowrap:不换行

                                            wrap:换行

                                            wrap-reverse:反转换行排列。

f ,align-content(行与行之间对齐方式)当伸缩容器的侧轴还有多余空间时,本属性可以用来调整「伸缩行」在伸缩容器里的对齐方式;

    align-content  属性值: flex-start行和行在侧轴顶端对齐,没有行间距

                                            flex-end行和行在侧轴顶端对未端对齐,没有行间距

                                            center行和行在侧轴居中对齐,没有行间距

                                            space-between行和行两端对齐,中间自动分配侧轴剩余空间。

                                            space-around行和行自动分配侧轴剩余空间。

                                            stretch 默认值。行和行补强制拉伸以适应容器侧轴的长度。

                                            space-evenly平均分配空白空间

        g,align-self(加给子元素)(align-self属性规定灵活容器内被选中项目的侧轴对齐方式。

                                                       注意:align-self属性可重写灵活容器的align-items属性。)

             align-self    属性值    auto默认值。元素继承了它的父容器的align-items属性。如果没有

容器则为"stretch"。                Stretch元素被拉伸以适应容器侧轴的尺寸。

                                                Center 元素位于容器侧轴的中心。     

                                                flex-start元素位于容器的侧轴顶端。

                                                flex-end元素位于容器侧轴的末端。

            h,flex三个子属性介绍   

             flex-grow        定义项目的放大比例,默认为0,即如果存在剩余空间也不放大

             flex-shrink        定义了项目的收缩比例,默认为1,即如果空间不足该项目将缩小。负值对该属性无效。收缩量的计算方式:(元素宽度*收缩比例/元素*收比例相加)*溢出宽度

            flex-basis        项目的主轴方向的长度

           j,flex (flex-grow,flex-shrink、flex-basis)

               复合属性。设置或检索弹性盒模型对象的子元素如何分配剩余空间。缩写「flex: 1」,则其计算值为「11 %]

              缩写「flex: auto」,则其计算值为「1 1 auto]flex: none」,则其计算值为「0 0 auto]

             flex: 0 auto」或者「flex: initial」,则其计算值为「0 1 auto」,即「flex」初始值

     k,order   

          说明:控制伸缩项目的显示的顺序,数字越大越往后排,默认为0,支持负数,没有单位的整数值。

   l、flex-flow  

         flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值