文章目录
- 简介
- 盒子模型
- 概念
- 版心居中
- Flex布局
- 组成
- 主轴对齐方式
- 侧轴对齐方式
- 修改主轴方向
- 弹性伸缩比
- 弹性盒子换行
- 行对齐方式
- 案例-抖音解决方案
- 效果图
- 案例分析
- 参考代码
- 领取完整源码
简介
在阅读本文之前,请确保你已经掌握CSS基本语法、常用属性以及CSS选择器。
盒模型是CSS布局的重要概念,它可以调整不同元素之间和元素内部之间的间距。
Flex布局是目前企业开发中常用的弹性灵活布局方案,常用于响应式和移动端开发。
本文总结了盒模型和Flex布局常用属性,可作为文档在使用时进行查阅。
盒子模型
概念
盒子模型是CSS的重要概念,用于布局组件,设置组件与组件之间和组件内部的间距。
盒子模型组成部分:
- 内容区域:width & height
- 内边距:padding
- 边框线:border
- 外边距:margin
我们通常将div作为盒子,padding即边框和内容之间的间距,border即盒子边框线,margin则是盒子与盒子之间的间距。
默认情况,指定盒模型的width和height是内容区域的大小。我们可以通过box-sizing: border-box;属性设置盒子大小为包含padding和margin的大小。
本文重点讲解Flex布局,关于盒模型的具体细节可以参考w3school。如果感兴趣可以了解下margin的合并和塌陷问题。
版心居中
我们通常使用auto来使版心居中:
div {margin: 0 auto;
}
Flex布局
Flex布局即CSS弹性盒子模型(Flexible Box 或 Flexbox),实现网页在不同分辨率设备上自适应而生的一种布局方式。
flex布局常用属性:
描述 | 属性 |
---|---|
创建flex容器 | display: flex |
主轴对齐方式 | justify-content |
侧轴对齐方式 | align-items |
某个弹性盒子侧轴对齐方式 | align-self |
修改主轴方向 | flex-direction |
弹性伸缩比 | flex |
弹性盒子换行 | flex-wrap |
行对齐方式 | align-content |
组成
设置方式:给父元素设置display: flex;子元素可以自动挤压和拉伸。
组成部分:
- 弹性容器
- 弹性盒子
- 主轴:默认在水平方向。
- 侧轴/交叉轴:默认在垂直方向。
例:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>flex布局-组成</title><style>/* 弹性容器 */.box {height: 300px;border: 1px solid #000;}/* 弹性盒子:沿着主轴方向排列 */.box div {width: 200px;height: 100px;background-color: pink;}</style>
</head>
<body><div class="box"><div>1</div><div>2</div><div>3</div></div>
</body>
</html>
div为块级元素,因此效果如下图所示:
我们设置父级的display为flex:
.box {display: flex;height: 300px;border: 1px solid #000;}
div成了弹性盒子,自动排列成了一行:
如果我们多放几个div:
<body><div class="box"><div>1</div><div>2</div><div>3</div><div>1</div><div>2</div><div>3</div><div>1</div><div>2</div><div>3</div></div>
</body>
</html>
弹性盒子的宽度会自动挤压,排列在一行:
主轴对齐方式
盒子之间的间距往往通过margin设置,但在flex布局中的弹性盒子的间距可以使用justify-content属性设置主轴对齐方式来实现。
常见的justify-content属性值如下:
属性值 | 效果 |
---|---|
flex-start | 默认值,弹性盒子从起点开始依次排列 |
flex-end | 弹性盒子从终点开始依次排列 |
center | 弹性盒子沿主轴居中排列 |
space-between | 弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子之间 |
space-around | 弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子两侧 |
space-evenly | 弹性盒子沿主轴均匀排列,弹性盒子与容器之间间距相等 |
flex-start:
flex-end:
center:
space-between(父级剩余宽度平均分配在弹性盒子之间):
space-around(父级剩余宽度平均分配在弹性盒子两侧,弹性盒子之间的距离是两侧的2倍):
space-evenly(弹性盒子之间、弹性盒子与弹性容器之间间距相等):
侧轴对齐方式
通过align-items可以控制弹性盒子在侧轴的对齐方式,也可以通过align-self属性单独控制某个弹性盒子在侧轴对齐方式。
常用属性值如下:
属性值 | 效果 |
---|---|
stretch | 弹性盒子沿侧轴线拉伸至铺满容器 |
center | 弹性盒子沿侧轴居中 |
flex-start | 弹性盒子从侧轴起点依次排列 |
flex-end | 弹性盒子从侧轴终点依次排列 |
stretch(弹性盒子在侧轴没有尺寸才能拉伸):
center:
flex-start:
flex-end:
通过结构伪类选择器,单独设置第二个div为center:
.box div:nth-child(2) {align-self: center;
}
修改主轴方向
flex-direction可以改变主轴方向,常用属性值:
属性值 | 效果 |
---|---|
row | 水平方向,从左向右(默认) |
column | 垂直方向,从上向下 |
row-reverse | 水平方向,从右向左 |
column-reverse | 垂直方向,从下向上 |
row和column效果依次如下:
弹性伸缩比
弹性伸缩比可以控制弹性盒子的主轴方向的尺寸,通过flex属性进行控制,属性值为整数表示占用父级剩余尺寸的份数。
例如,对下面四个弹性容器进行排版,每个弹性容器的份数都设置为1,则4个弹性容器就可以均分父级尺寸。
设置div1固定宽度,div2的flex: 1, div3的flex:2。效果如下图所示:
弹性盒子换行
通过flex-wrap属性可以设置换行,属性值分为wrap(换行)和nowrap(不换行,默认)。
flex-wrap: wrap效果如下图所示:
行对齐方式
上面我们已经实现了弹性盒子自动换行,现在可以通过align-content设置行与行的对齐方式。
align-content的常见属性值(和主轴对齐方式justify-content一致):
属性值 | 效果 |
---|---|
flex-start | 默认值,弹性盒子从起点开始依次排列 |
flex-end | 弹性盒子从终点开始依次排列 |
center | 弹性盒子沿主轴居中排列 |
space-between | 弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子之间 |
space-around | 弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子两侧 |
space-evenly | 弹性盒子沿主轴均匀排列,弹性盒子与主轴之间间距相等 |
案例-抖音解决方案
效果图
案例分析
- 这里使用的是无序列表ul,因此需要创建div > ul > li *4。
- 对列表项ul进行布局,可以使用float或flex,推荐使用flex。
- 需要换行,因此使用flex-wrap: wrap。
- 分析单独一行,发现间距在两个div之间,因此主轴对齐方式可以使用space-between。
- 行与行间距也在div之间,因此行对齐方式采用space-between。
参考代码
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>抖音解决方案</title><style>* {/* 清除默认样式 */margin: 0;padding: 0;/* 使盒模型尺寸包含border和padding */box-sizing: border-box;}li {list-style: none;}.box {margin: 50px auto;width: 1200px;height: 418px;border: 1px solid #ddd;border-radius: 10px;}.box ul {display: flex;/* 弹性盒子换行 */flex-wrap: wrap;/* 调整主轴对齐方式 */justify-content: space-between;/* 调整 行对齐方式 */align-content: space-between;padding: 90px 40px 90px 60px;height: 418px;}.box li {display: flex;width: 500px;height: 88px;/* background-color: pink; */}.box .pic {margin-right: 15px;}.box .text h4 {line-height: 40px;font-size: 20px;font-weight: 400;color: #333;}.box .text p {font-size: 14px;color: #666;}</style>
</head>
<body><div class="box"><ul><li><div class="pic"><img src="./images/1.svg" alt=""></div><div class="text"><h4>一键发布多端</h4><p>发布视频到抖音短视频、西瓜视频及今日头条</p></div></li><li><div class="pic"><img src="./images/2.svg" alt=""></div><div class="text"><h4>管理视频内容</h4><p>支持修改已发布稿件状态和实时查询视频审核状态</p></div></li><li><div class="pic"><img src="./images/3.svg" alt=""></div><div class="text"><h4>发布携带组件</h4><p>支持分享内容携带小程序、地理位置信息等组件,扩展内容及突出地域性</p></div></li><li><div class="pic"><img src="./images/4.svg" alt=""></div><div class="text"><h4>数据评估分析</h4><p>获取视频在对应产品内的数据表现、获取抖音热点,及时进行表现评估</p></div></li></ul></div>
</body>
</html>
领取完整源码
关注微信公众号:Real返璞归真,后台回复【抖音解决方案】获取完整源代码+素材下载地址。
本公众号不定期更新前后端开发、算法/数据结构、网络安全相关知识,欢迎关注,为我提供更多创作动力。