深入探索Flex布局:从基础到实战,附带抖音解决方案案例分析

文章目录

  • 简介
  • 盒子模型
    • 概念
    • 版心居中
  • Flex布局
    • 组成
    • 主轴对齐方式
    • 侧轴对齐方式
    • 修改主轴方向
    • 弹性伸缩比
    • 弹性盒子换行
    • 行对齐方式
    • 案例-抖音解决方案
      • 效果图
      • 案例分析
      • 参考代码
  • 领取完整源码

简介

在阅读本文之前,请确保你已经掌握CSS基本语法、常用属性以及CSS选择器。

盒模型是CSS布局的重要概念,它可以调整不同元素之间和元素内部之间的间距。

Flex布局是目前企业开发中常用的弹性灵活布局方案,常用于响应式和移动端开发。

本文总结了盒模型和Flex布局常用属性,可作为文档在使用时进行查阅。

盒子模型

概念

盒子模型是CSS的重要概念,用于布局组件,设置组件与组件之间和组件内部的间距。

盒子模型组成部分:

  • 内容区域:width & height
  • 内边距:padding
  • 边框线:border
  • 外边距:margin

image-20240212173453698

我们通常将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;子元素可以自动挤压和拉伸。

组成部分:

  • 弹性容器
  • 弹性盒子
  • 主轴:默认在水平方向。
  • 侧轴/交叉轴:默认在垂直方向。
image-20240211213127279

例:

<!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为块级元素,因此效果如下图所示:

image-20240211213701613

我们设置父级的display为flex:

.box {display: flex;height: 300px;border: 1px solid #000;}

div成了弹性盒子,自动排列成了一行:

image-20240211213520881

如果我们多放几个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>

弹性盒子的宽度会自动挤压,排列在一行:

image-20240211213632645

主轴对齐方式

盒子之间的间距往往通过margin设置,但在flex布局中的弹性盒子的间距可以使用justify-content属性设置主轴对齐方式来实现。

常见的justify-content属性值如下:

属性值效果
flex-start默认值,弹性盒子从起点开始依次排列
flex-end弹性盒子从终点开始依次排列
center弹性盒子沿主轴居中排列
space-between弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子之间
space-around弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子两侧
space-evenly弹性盒子沿主轴均匀排列,弹性盒子与容器之间间距相等

flex-start:

image-20240212163911515

flex-end:

image-20240212163858574

center:

image-20240212163843159

space-between(父级剩余宽度平均分配在弹性盒子之间):

image-20240212163948236

space-around(父级剩余宽度平均分配在弹性盒子两侧,弹性盒子之间的距离是两侧的2倍):

image-20240212164007946

space-evenly(弹性盒子之间、弹性盒子与弹性容器之间间距相等):

image-20240212164026992

侧轴对齐方式

通过align-items可以控制弹性盒子在侧轴的对齐方式,也可以通过align-self属性单独控制某个弹性盒子在侧轴对齐方式。

常用属性值如下:

属性值效果
stretch弹性盒子沿侧轴线拉伸至铺满容器
center弹性盒子沿侧轴居中
flex-start弹性盒子从侧轴起点依次排列
flex-end弹性盒子从侧轴终点依次排列

stretch(弹性盒子在侧轴没有尺寸才能拉伸):

image-20240212164835368

center:

image-20240212164857758

flex-start:

image-20240212164935254

flex-end:

image-20240212164954979

通过结构伪类选择器,单独设置第二个div为center:

.box div:nth-child(2) {align-self: center;
}
image-20240212165133259

修改主轴方向

flex-direction可以改变主轴方向,常用属性值:

属性值效果
row水平方向,从左向右(默认)
column垂直方向,从上向下
row-reverse水平方向,从右向左
column-reverse垂直方向,从下向上

row和column效果依次如下:

image-20240212170243572

弹性伸缩比

弹性伸缩比可以控制弹性盒子的主轴方向的尺寸,通过flex属性进行控制,属性值为整数表示占用父级剩余尺寸的份数。

例如,对下面四个弹性容器进行排版,每个弹性容器的份数都设置为1,则4个弹性容器就可以均分父级尺寸。

image-20240212170800025

设置div1固定宽度,div2的flex: 1, div3的flex:2。效果如下图所示:

image-20240212170954572

弹性盒子换行

通过flex-wrap属性可以设置换行,属性值分为wrap(换行)和nowrap(不换行,默认)。

flex-wrap: wrap效果如下图所示:

image-20240212171809509

行对齐方式

上面我们已经实现了弹性盒子自动换行,现在可以通过align-content设置行与行的对齐方式。

align-content的常见属性值(和主轴对齐方式justify-content一致):

属性值效果
flex-start默认值,弹性盒子从起点开始依次排列
flex-end弹性盒子从终点开始依次排列
center弹性盒子沿主轴居中排列
space-between弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子之间
space-around弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子两侧
space-evenly弹性盒子沿主轴均匀排列,弹性盒子与主轴之间间距相等

案例-抖音解决方案

效果图

image-20240212172500006

案例分析

  1. 这里使用的是无序列表ul,因此需要创建div > ul > li *4。
  2. 对列表项ul进行布局,可以使用float或flex,推荐使用flex。
  3. 需要换行,因此使用flex-wrap: wrap。
  4. 分析单独一行,发现间距在两个div之间,因此主轴对齐方式可以使用space-between。
  5. 行与行间距也在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返璞归真,后台回复【抖音解决方案】获取完整源代码+素材下载地址。

本公众号不定期更新前后端开发、算法/数据结构、网络安全相关知识,欢迎关注,为我提供更多创作动力。

wx_qrcode

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/679827.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机视觉讲座PPT分享

最近在电子工业出版社做的《计算机视觉入门路线图》讲座的部分PPT。 主要介绍了计算机视觉的学习基本路线。

推荐系统|行为序列_用户行为序列建模、Din模型和SIM模型

文章目录 用户行为序列建模Din模型Din模型的缺点 用户行为序列建模 物品ID通过Embedding将会得到一个向量&#xff0c;性质差不多的向量在空间中也会处于差不多的位置&#xff0c;可以用取平均方式得到一个综合所有向量的向量。 取平均后可以作为代表用户的一个特征。 以上的…

数据分析基础之《pandas(8)—综合案例》

一、需求 1、现在我们有一组从2006年到2016年1000部最流行的电影数据 数据来源&#xff1a;https://www.kaggle.com/damianpanek/sunday-eda/data 2、问题1 想知道这些电影数据中评分的平均分&#xff0c;导演的人数等信息&#xff0c;我们应该怎么获取&#xff1f; 3、问题…

SpringCloud-高级篇(二十二)

前面解决了消息的可靠性、消息的延迟问题&#xff0c;消息的堆积的问题&#xff0c;下面研究mq可用性、并发能力问题&#xff0c;这就需要mq集群来实现了 一&#xff1a;集群分类 &#xff08;1&#xff09;普通集群 创建一个节点&#xff1a; 8082、8083也可以看到这个队列&…

红队打靶练习:DEVGURU: 1

目录 信息收集 1、arp 2、nmap 3、dirsearch WEB web信息收集 8585端口 漏洞利用 提权 系统信息收集 横向渗透 get flag 信息收集 1、arp ┌──(root㉿ru)-[~/kali] └─# arp-scan -l Interface: eth0, type: EN10MB, MAC: 00:50:56:20:80:1b, IPv4: 192.168.10…

14.盔甲?装甲?装饰者模式!

人类的军工发展史就是一场矛与盾的追逐&#xff0c;矛利则盾坚&#xff0c;盾愈坚则矛愈利。在传统的冶金工艺下&#xff0c;更坚固的盾牌和盔甲往往意味着更迟缓笨重的运动能力和更高昂的移动成本。从战国末期的魏武卒、秦锐士&#xff0c;到两宋之交的铁浮图、重步兵&#xf…

HCIA-HarmonyOS设备开发认证V2.0-3.2.轻量系统内核基础-时间管理

目录 一、时间管理1.1、时间接口1.2、代码分析&#xff08;待续...&#xff09; 一、时间管理 时间管理以系统时钟为基础&#xff0c;给应用程序提供所有和时间有关的服务。系统时钟是由定时器/计数器产生的输出脉冲触发中断产生的&#xff0c;一般定义为整数或长整数。输出脉…

关于推挽电路的说明

推挽电路,是一个我们时常遇到的一种电路,或者听过的一种电路,比如设置单片机的输出模式时,就有推挽输出这种选项。 由双极型晶体管即三极管组成的推挽电路基本上就是下图所示。 而推完的路径无非就是两种,如图示: 具体的输入输出原理就不说了,这里有一个及其关键的问题…

【JavaScrpt 漫游】【015】JSON 对象简记

文章简介 本文为【JavaScript 漫游】专栏的第 015 篇文章&#xff0c;主要是对 JS 语言中的 JSON 对象的知识点进行了简要记录。 JSON 格式JSON 对象JSON.stringify()JSON.parse() JSON 格式 JSON 格式&#xff08;JavaScript Object Notation 的缩写&#xff09;是一种用于…

【原创 附源码】Flutter安卓及iOS海外登录--Google登录最详细流程

最近接触了几个海外登录的平台&#xff0c;踩了很多坑&#xff0c;也总结了很多东西&#xff0c;决定记录下来给路过的兄弟坐个参考&#xff0c;也留着以后留着回顾。更新时间为2024年2月8日&#xff0c;后续集成方式可能会有变动&#xff0c;所以目前的集成流程仅供参考&#…

Linux第49步_移植ST公司的linux内核第1步_获取linux源码

已知ST公司的linux源码路径&#xff1a; /home/zgq/linux/atk-mp1/stm32mp1-openstlinux-5.4-dunfell-mp1-20-06-24/sources/arm-ostl-linux-gnueabi/linux-stm32mp-5.4.31-r0 1、创建“my_linux”目录 打开第1个终端 输入“ls回车” 输入“cd linux/回车”&#xff0c;切换…

IDEA Ultimate下载(采用JetBrain学生认证)

IDEA Ultimate版本下载 Ulitmate是无限制版&#xff08;解锁所有插件&#xff0c;正版需要付费。学生可以免费申请许可&#xff09;Community是开源社区版本&#xff08;部分插件不提供使用&#xff0c;比如Tomcat插件。免费&#xff09; 我们将通过学生认证获取免费版。 Je…

例38:使用Frame(分组框)

建立一个EXE工程&#xff0c;在窗体上放两个Frame框。分别放两组单选按钮表示性别和收入&#xff0c;注意每组单选按钮的组名要一样。在按钮中输入代码&#xff1a; Sub Form1_Command1_BN_Clicked(hWndForm As hWnd, hWndControl As hWnd)If Frame1.Visible ThenFrame1.Visib…

[算法学习] 逆元与欧拉降幂

费马小定理 两个条件&#xff1a; p为质数a与p互质 逆元 如果要求 x^-1 mod p &#xff0c;用快速幂求 qmi(x,p-2) 就好 欧拉函数 思路&#xff1a;找到因数 i&#xff0c;phi / i * (i-1)&#xff0c;除干净&#xff0c;判断最后的n 欧拉降幂 欧拉定理 应用示例 m! 是一个…

【实战】一、Jest 前端自动化测试框架基础入门 —— 前端要学的测试课 从Jest入门到TDD BDD双实战(一)

文章目录 一、前端要学的测试课1.前端要学的测试2.前端工程化的一部分3.前端自动化测试的例子4.前端为什么需要自动化测试&#xff1f;5.课程涵盖内容6.前置技能7.学习收获 二、Jest 前端自动化测试框架基础入门1. 自动化测试背景及原理前端自动化测试产生的背景及原理 2.前端自…

【JVM篇】ThreadLocal中为什么要使用弱引用

文章目录 &#x1f354;ThreadLocal中为什么要使用弱引用⭐总结 &#x1f354;ThreadLocal中为什么要使用弱引用 ThreadLocal可以在线程中存放线程的本地变量&#xff0c;保证数据的线程安全 ThreadLocal是这样子保存对象的&#xff1a; 在每个线程中&#xff0c;存放了一个…

2024牛客寒假算法基础集训营3

前言 感觉有些题是有难度&#xff0c;但是是我花时间想能想的出来的题目&#xff0c;总体来说做的很爽&#xff0c;题目也不错。个人总结了几个做题技巧&#xff0c;也算是提醒自己。 1.多分类讨论 2.从特殊到一般&#xff0c;便于找规律。例如有一组数&#xff0c;有奇数和…

【嵌入式-定时器】通过呼吸灯案例使用逻辑分析仪分析PWM波形

目的&#xff1a;通过实现呼吸灯分析PWM波形 代码&#xff1a; PWM.c #include "stm32f10x.h" // Device header/*** brief PWM初始化* param 无* retval 无 */ void PWM_Init(void) {// 使能IO和TIM2RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM…

错误的集合(力扣刷题)

个人主页&#xff08;找往期文章包括但不限于本期文章中不懂的知识点&#xff09;&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 由于作者比较菜&#xff0c;还没学malloc这个函数&#xff0c;因此这个题目只写一些与原题大致的思路。 题目链接&#xff1a;645. 错误的集合 - 力扣…