CSS3 Flex布局

本文介绍了CSS3的Flex布局,重点讲述了Flexbox的主要思想和应用场景,包括主轴、侧轴的概念,以及justify-content、align-items等属性的用法。通过实战案例展示了如何使用Flex布局实现‘三栏布局’,并解释了伸缩性如何控制子元素在容器中的扩展和收缩。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CSS2.1布局
1. 块布局:呈现文档的布局模式
2. 行内布局:呈现文本的布局模式
3. 表格布局:用格子呈现2D数据的布局模式
4. 定位布局:能够直接地定位元素的布局模式

Flex布局常用于设计比较复杂的页面,可以轻松的实现浏览器窗口大小发生变化时保持元素的相对位置和大小不变,同时减少了依赖于浮动布局实现元素位置的定义以及重置元素的大小。比如传统的布局方式是基于盒模型,依赖于display、position属性或者是float属性,但是在传统的布局上面并不好布局; 比如我们想让某个元素垂直居中的话,我们常见的会让其元素表现为表格形式,比如display:table-cell属性什么的,而使用flex布局是非常方便的


CSS3引入的布局模式Flexbox布局,主要思想是让容器有能力让其子项目能够改变其宽度、高度(甚至顺序),以最佳的方式填充可用空间(主要是为了适应所有类型的显示设备和屏幕大小)。

flex

(1)主轴:通过这个伸缩盒子特性,可以很好的管理伸缩项目在伸缩盒子中的布局方向。这个(伸缩流)方向可以是从左到右,从上到下,从下到上,从右到左。这个主轴的方向可以通过flex-direction属性来定义值分别为row,row-reverse,column,column-reverse。
(2)主轴起点和终点:伸缩项目从主轴起点开始布局到终点结束。属性justify-content就是根据主轴的起点和终点赋予start,center,end等值来布局的。
(3)侧轴:与主轴垂直的轴是侧轴,所以说,侧轴的方向是由主轴决定的。
(4)侧轴的起点和终点:伸缩项目充满伸缩行,并且伸缩行从侧轴起点开始布局容器到侧轴终点结束。

flexbox规范版本众多,浏览器对此语法支持度也各有不同:
兼容性


在这里就不一一讲解属性,文档上都有各个属性的声明。
传送门 => 配图理解属性文章


定义flex布局:当一个元素变成了伸缩容器,其子元素会自动变成伸缩项目(注:定义之后,子元素的float、clear、vertical-align不再有效)
display

display: -moz-box;  /*旧版本:FF19-*/  
display: -webkit-box;  /*旧版本 ios6-,safari 3.1-6*/  
display: box;  

display: -ms-flexbox;  /*混合版本:IE10*/  

display: -webkit-flex;  /*新版本:chrome等*/  
display: flex;  /*w3c标准*/ 


指定主轴(伸缩流)方向:只要主轴方向确定下来,垂直于它的侧轴也会随着确定下来。
主轴方向

//主轴方向从左到右
.row{
    -moz-box-orient: horizontal;
    -webkit-box-orient: horizontal;
    box-orient: horizontal;

    -ms-flex-direction: row;

    -webkit-flex-direction: row;
    flex-direction: row;
}

row

//主轴方向从右到左
.row-reverse{
    -moz-box-orient: horizontal;
    -webkit-box-orient: horizontal;
    box-orient: horizontal;

    -ms-flex-direction: row-reverse;

    -webkit-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

row-reverse

//主轴方向从上到下
.column{
    -moz-box-orient: vertical;
    -webkit-box-orient: vertical;
    box-orient: vertical;

    -ms-flex-direction: column;

    -webkit-flex-direction: column;
    flex-direction: column;
}

column

//主轴方向从下到上
.column-reverse{
    margin-top: 10px;
    -moz-box-orient: vertical;
    -webkit-box-orient: vertical;
    box-orient: vertical;

    -ms-flex-direction: column-reverse;

    -webkit-flex-direction: column-reverse;
    flex-direction: column-reverse;
}

column-reverse


主轴对齐:指的是该”容器”下所有子项目主轴的对齐方式。其实类似于word文档里面文字的左对齐、居中对齐、右对齐、还有它本身的两端对齐、扩散对齐等
主轴对齐


侧轴对齐:指的是该”容器”下所有子项目侧轴的对齐方式。其实类似于word文档里面文字的左对齐、居中对齐、右对齐、还有它本身的基线对齐、拉伸对齐等
侧轴对齐


显示顺序:与主/侧轴对齐不一样的地方是,这个作用在”子项目”下,分别对内部的各个子项目位置进行调整。(注:如果该数值小于0,那么则按照0计算。默认情况下为0。值越大越靠后显示)
显示顺序

-moz-box-ordinal-group: 1;
-webkit-box-ordinal-group: 1;
box-ordinal-group: 1;

-ms-flex-order: 1;

-webkit-order: 1;
order: 1;

比如给box1设置为1,box2设置为2,box3设置为3,box4不做任何设置(默认为0)。此时显示顺序:4->1->2->3


换行:控制伸缩项目在没有足够空间的伸缩容器中是否换行(注:这里的box-lines对所有浏览器都不兼容,因此在实际项目中不会使用)
换行

.nowrap{
    //默认值
    -moz-box-lines: single; /*无效*/
    -webkit-box-lines: single; /*无效*/
    box-lines: single; /*无效*/

    -ms-flex-wrap: nowrap;

    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
}
.wrap{
    -moz-box-lines: multiple; /*无效*/
    -webkit-box-lines: multiple; /*无效*/
    box-lines: multiple; /*无效*/

    -ms-flex-wrap: wrap;

    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}


伸缩性:控制伸缩项目在伸缩容器中 扩展或收缩 伸缩项目的宽度,用来填充伸缩容器的额外空间
伸缩性

这里重点介绍伸缩性box-flex/flex

伸缩性属性能够灵活地控制子项目在容器中的显示空间(注:这里的显示空间包括项目的宽度和高度)

在一个水平导向框中,首先会计算每个子项目的宽度。
1. 如果所有子项目的宽度之和等于容器宽度,容器就没有额外的空间,这个时候运用在子项目的宽度是每个子项目的宽度。
2. 如果所有子项目的宽度之和小于容器宽度,容器就有额外的空间可用,子项目会根据box-flex/flex属性对应的比例进行扩展。
3. 如果所有子项目的宽度之和大于容器宽度,容器没有额外的空间,子项目会根据box-flex/flex属性对应的比例进行收缩,以防子项目溢出容器外。

考虑第(2)种情况:
小于

-moz-box-flex: 1;
-webkit-box-flex: 1;
box-flex: 1;

-ms-flex: 1;

-webkit-flex: 1;
flex: 1;

此时将第一个box_240设置为1份,box_510设置为2份。此时会将额外空间210px平均分为三份,每份宽度为70px。box_240将获得70px,box_510将获得70*2px。

结果如图:
结果


考虑第(3)种情况:
大于

这个时候,子项目总宽度溢出了340px。为了不让子项目溢出容器,需要在子项目上设置box-flex/flex属性。

box_240设置为1,box_510设置为1。将溢出的部分平分340px,每份170px,这个时候子项目会按照比例进行收缩。由于都是1份,所以box_240和box_510分别都收缩170px。

结果如图
结果

实战:”三栏布局”

<div id="header">header</div>
<div id="page">
    <div id="main">main</div>
    <div id="sidebar-left">left</div>
    <div id="sidebar-right">right</div>
</div>
<div id="footer">footer</div>
*{
    margin: 0;
    padding: 0;
}
html,body{
    height: 100%;
}
body{
    display: -moz-box;
    display: -webkit-box;
    display: box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;

    -moz-box-orient: vertical;
    -webkit-box-orient: vertical;
    box-orient: vertical;
    -ms-flex-direction: column;
    -webkit-flex-direction: column;
    flex-direction: column;
}

#header,#footer{
    height: 50px;
    background: #ccc;
    text-align: center;
    line-height: 50px;
}
#sidebar-left,#sidebar-right{
    width: 220px;
    background: #f36;
    padding: 10px;

    -moz-box-flex: 2;
    -webkit-box-flex: 2;
    box-flex: 2;
    -ms-flex: 2;
    -webkit-flex: 2;
    flex: 2;
}
#sidebar-right{
    -moz-box-ordinal-group: 3;
    -webkit-box-ordinal-group: 3;
    box-ordinal-group: 3;
    -ms-flex-order: 3;
    -webkit-order: 3;
    order: 3;
}
#main{
    background: pink;
    padding: 10px;

    -moz-box-flex: 5;
    -webkit-box-flex: 5;
    box-flex: 5;
    -ms-flex: 5;
    -webkit-flex: 5;
    flex: 5;

    -moz-box-ordinal-group: 2;
    -webkit-box-ordinal-group: 2;
    box-ordinal-group: 2;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
}
#page{
    text-align: center;

    display: -moz-box;
    display: -webkit-box;
    display: box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;

    -moz-box-flex: 1;
    -webkit-box-flex: 1;
    box-flex: 1;
    -ms-flex: 1;
    -webkit-flex: 1;
    flex: 1;
}

三栏布局

高速公路坐标高程计算软件是在多年的施工放样工作中总结出来的一个很有效的程序。它是公路、铁路施工放样的好助手,可以帮你完成以前你用很大的精力和时间完成的计算。它能在工作中给予很大的方便,使你能从繁琐的计算工作中解脱出来,你只要按要求将已知的几个数据输入即可,并大大的提高了计算精确性和准确性。操作简便、实用,适合采用坐标法放样,如具有全站仪和测距仪的测量放线工作,快速准确定位,很有推广价值。 高速公路坐标高程计算软件可以帮你完成直线、圆曲线、缓和曲线(完全缓和曲线和不完全缓和曲线)、S形曲线、复曲线、试车场高速环道布劳斯曲线的中桩和任意长度、任意角度边桩坐标高程计算,并可根据你有要求加任意点的坐标计算方法根据曲线是否完整对称可以选择交点法计算和特殊点计算方法。生成的坐标成果可以直接通过数据线导入全站仪,也可以导入Excel中便于打印,导入AUTOCAD中生成DWG图形,根据线形是否平顺来检验坐标准确性。 高速公路坐标高程计算软件应用于公路、铁路、等坐标高程计算,可用来计算桥梁桩基、立柱、支座垫石、护栏、桥面系及涵洞通道坐标高程,可计算试车场高速环道布劳斯曲线坐标,是施工放样和图纸坐标高程复核的好帮手,还可以用来复核工程上广泛应用的可编程计算器CASIO 5800坐标高程避免出错。 他是一个免费软件,没有任何限制。附送CASIO4850,5800程序及算法。 高速公路坐标高程计算软件简要说明: 一、线元法计算平曲线(主程序) 1、J为起算点里程,C、D为起算点的X、Y坐标,F为起算点的切线方位角,R为圆曲线半径(左偏取负,右偏取正),A、B为第一、第二缓和曲线回旋参数,O为圆曲线长度,Ki为该分段的终点里程; 2、对于直线段或圆曲线段,起算点可取直线或圆曲线上的任意一点; 3、对于带第一、第二缓和曲线的平曲线段,起算点应取HY点; 4、K为所求点的里程,T、P为第一偏距、偏角,S、Z为第二偏距、偏角,偏角取从该点的切线顺时针旋转的夹角; 5、分段法则:直线单独分段;单一的圆曲线单独分段;缓和曲线1 圆曲线 缓和曲线2为一个整体单独分段,若不存在第一或第二缓和曲线(即不完全缓和曲线)仍然可以计算;若不存在圆曲线,则O取零; 6、对于两圆夹一段缓和曲线分段这种类型,缓和曲线应该分到半径较小的那个圆上,因为程序算法本来就是从HY和YH点小半径R向大半径∞方向进行推算的,不同于以往从ZH或HZ点计算,从ZH或HZ点推算是从大半径∞向小半径R方向进行推算的。这种情况下回旋参数A=根号下√abs(LsR1R2/(R1-R2)),Ls为缓和曲线长,R1,R2为半径。 7、若第一或者第二缓和曲线不存在,此时A或B可取零; 8、F、Q切线方位角输入输出均为度.分秒的格式,例如153°24′05.24″=153.240524。Q改变时,可按照新方位角为基准,结合第一第二偏距、偏角重新计算所求点; 9、输入平曲线参数后,默认为计算全线坐标,可修改来计算某段曲线,默认间距也可修改; 10、可参考CAD图《平曲线计算图例》; 11、生成的中桩CAD脚本设置成在世界坐标系下生成,注意的是世界坐标系与大地测量坐标系的区别是XY坐标是互换的,否则画出的图形与实际相反。先打开CAD,设置好图层名称、颜色,并设置为当前层,然后单击CAD的工具==》运行脚本==》选中生成的脚本文件即可。 12、输出的坐标结果可以导入到EXCEL中,操作办法为:打开EXCEL,然后把坐标数据复制到单元格里,然后单击数据==》分列==》选中分隔符号==》下一步==》选中TAB键和逗号==》下一步==》完成即可。下一次可直接在此表中粘贴,数据自动分列。 二、缓和曲线计算(辅助程序) 1、本程序为辅助程序,用来从ZH点或HZ点计算整条完全的缓和曲线,若不知道HY点X、Y、Q参数,可用此程序计算出来,然后输入平曲线参数; 2、参数设置参考平曲线计算3、导出到EXCEL的办法同平曲线计算; 三、直线计算(辅助程序) 1、本程序为辅助程序,若已知P1(X1,Y1),P1--》P2的距离I及方位角J(度.分秒格式),可计算坐标P2(X2,Y2)。 四、方位角计算 1、已知两点的坐标,可计算P1--》P2的距离及方位角; 2、角度可以进行加减运算。(单位:度.分秒格式) 五、竖曲线计算(主程序) 1、J为起算点里程,Y为起算点的高程,R为圆曲线半径(取绝对值),E、F为第一、第二坡度,不带%号,例如2.5%的坡度就输入2.5,上坡取正值,下坡取负值; 2、K为所求点的里程,T为边桩到设计高程点的斜距,I为横坡,向外流水取正,向中流水取负,G为边桩的高程3、分段法则:以两竖曲线之间直线段中间的任意一点为分界,如上图中的K1、K2、K3;注意分离式路基一般要单独分段,分段时如果从起点就开始变坡,第一个分段起点必须与终点里程应相同或小1毫米,否则程序不能计算第一个分段的横坡; 4、无论任何时候R不能取零,否则可能导致被零除的错误; 5、可参考CAD图《竖曲线计算图例》; 6、导出到EXCEL的办法同平曲线计算; 六、交点法点计算平曲线(辅助程序) 1、交点法计算平曲线功能,是用来计算对称的完全缓和曲线的,如果特征点里程与图纸不符,必须查明原因,比如是由断链或者不完全缓和曲线引起的。 2、最后一个交点如果R、Ls、T、L如果不知道,R随便输入一个不为零的数字比如111,Ls、T、L输入零就可以了。 高速公路坐标高程计算软件截图
安装后c盘有源代码。 高速公路坐标高程计算软件 高速公路坐标高程计算软件是在多年的施工放样工作中总结出来的一个很有效的程序。 它是公路、铁路施工放样的好助手,可以帮你完成以前你用很大的精力和时间完成的计算。 它能在工作中给予很大的方便,使你能从繁琐的计算工作中解脱出来,你只要按要求将已 知的几个数据输入即可,并大大的提高了计算精确性和准确性。操作简便、实用,适合采 用坐标法放样,如具有全站仪和测距仪的测量放线工作,快速准确定位,很有推广价值。 高速公路坐标高程计算软件可以帮你完成直线、圆曲线、缓和曲线(完全缓和曲线和 不完全缓和曲线)、S形曲线、复曲线、试车场高速环道布劳斯曲线的中桩和任意长度、任 意角度边桩坐标高程计算,并可根据你有要求加任意点的坐标计算方法根据曲线是 否完整对称可以选择交点法计算和特殊点计算方法。生成的坐标成果可以直接通过数据线 导入全站仪,也可以导入Excel中便于打印,导入AUTOCAD中生成DWG图形,根据线形是否平 顺来检验坐标准确性。 高速公路坐标高程计算软件应用于公路、铁路、等坐标高程计算,可用来计算桥梁桩基、 立柱、支座垫石、护栏、桥面系及涵洞通道坐标高程,可计算试车场高速环道布劳斯曲线坐 标,是施工放样和图纸坐标高程复核的好帮手,还可以用来复核工程上广泛应用的可编程计 算器CASIO 5800坐标高程避免出错。 他是一个免费软件,没有任何限制。附送CASIO4850,5800程序及算法。 下载地址:天空软件站,搜索高速公路坐标高程计算。 本软件简要说明: 一、线元法计算平曲线(主程序) 1、J为起算点里程,C、D为起算点的X、Y坐标,F为起算点的切线方位角,R为圆曲线半径 (左偏取负,右偏取正),A、B为第一、第二缓和曲线回旋参数,O为圆曲线长度,Ki为该 分段的终点里程; 2、对于直线段或圆曲线段,起算点可取直线或圆曲线上的任意一点; 3、对于带第一、第二缓和曲线的平曲线段,起算点应取HY点; 4、K为所求点的里程,T、P为第一偏距、偏角,S、Z为第二偏距、偏角,偏角取从该点的 切线顺时针旋转的夹角; 5、分段法则:直线单独分段;单一的圆曲线单独分段;缓和曲线1+圆曲线+缓和曲线2为一 个整体单独分段,若不存在第一或第二缓和曲线(即不完全缓和曲线)仍然可以计算; 若不存在圆曲线,则O取零; 6、对于两圆夹一段缓和曲线分段这种类型,缓和曲线应该分到半径较小的那个圆上,因为 程序算法本来就是从HY和YH点小半径R向大半径∞方向进行推算的,不同于以往从ZH或HZ点计算, 从ZH或HZ点推算是从大半径∞向小半径R方向进行推算的。 这种情况下回旋参数A=根号下√abs(Ls*R1*R2/(R1-R2)),Ls为缓和曲线长,R1,R2为半径。 7、若第一或者第二缓和曲线不存在,此时A或B可取零; 8、F、Q切线方位角输入输出均为度.分秒的格式,例如153°24′05.24″=153.240524。 Q改变时,可按照新方位角为基准,结合第一第二偏距、偏角重新计算所求点; 9、输入平曲线参数后,默认为计算全线坐标,可修改来计算某段曲线,默认间距也可修改; 10、可参考CAD图《平曲线计算图例》; 11、生成的中桩CAD脚本设置成在世界坐标系下生成,注意的是世界坐标系与大地测量坐标系 的区别是XY坐标是互换的,否则画出的图形与实际相反。先打开CAD,设置好图层名称、颜色, 并设置为当前层,然后单击CAD的工具==>运行脚本==>选中生成的脚本文件即可。 12、输出的坐标结果可以导入到EXCEL中,操作办法为:打开EXCEL,然后把坐标数据复制到 单元格里,然后单击数据==>分列==>选中分隔符号==>下一步==>选中TAB键和逗号==>下一步 ==>完成即可。下一次可直接在此表中粘贴,数据自动分列。 二、缓和曲线计算(辅助程序) 1、本程序为辅助程序,用来从ZH点或HZ点计算整条完全的缓和曲线, 若不知道HY点X、Y、Q参数,可用此程序计算出来,然后输入平曲线参数; 2、参数设置参考平曲线计算3、导出到EXCEL的办法同平曲线计算; 三、直线计算(辅助程序) 1、本程序为辅助程序,若已知P1(X1,Y1),P1-->P2的距离I及方位角J(度.分秒格式), 可计算坐标P2(X2,Y2)。 四、方位角计算 1、已知两点的坐标,可计算P1-->P2的距离及方位角; 2、角度可以进行加减运算。(单位:度.分秒格式) 五、竖曲线计算(主程序) 1、J为起算点里程,Y为起算点的高程,R为圆曲线半径(取绝对值),E、F为第一、 第二坡度,不带%号,例如2.5%的坡度就输入2.5,上坡取正值,下坡取负值; 2、K为所求点的里程,T为边桩到设计高程点的斜距,I为横坡,向外流水取正, 向中流水取负,G为边桩的高程3、分段法则:以两竖曲线之间直线段中间的任意一点为分界,如上图中的K1、K2、K3; 注意分离式路基一般要单独分段,分段时如果从起点就开始变坡,第一个分段起点必须 与终点里程应相同或小1毫米,否则程序不能计算第一个分段的横坡; 4、无论任何时候R不能取零,否则可能导致被零除的错误; 5、可参考CAD图《竖曲线计算图例》; 6、导出到EXCEL的办法同平曲线计算; 六、交点法点计算平曲线(辅助程序) 1、交点法计算平曲线功能,是用来计算对称的完全缓和曲线的,如果特征点里程与图纸不符, 必须查明原因,比如是由断链或者不完全缓和曲线引起的。 一般地,匝道用线元法,主线用交点法,因为匝道的线型不一定是标准的交点法线型,如果不是标准的交点法线型,用常规方法推算是不对的,交点法适用于缓1+圆+缓2这种线型,对于缓1+圆1+缓2+圆2这种,缓2是分到圆1还是圆2上是有区别的,如果缓2分到半径小的圆上就适用交点法,反之则不适用。 2、最后一个交点如果R、Ls、T、L如果不知道,R随便输入一个不为零的数字比如111, Ls、T、L输入零就可以了。 七、其他说明 1、本程序是在WINXP下编译的,如果在WIN98、WIN2000下运行提示少DLL文件的话可以从网 上下载,拷贝到%windir%\system及system32目录,并用示例的格式来注册。 2、本软件梦(QQ704728827)和陈晓猫(QQ43308724)共同编写完成,有错误欢迎指正。 EMAIL:liuzhao3@163.com。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值