flex布局应用与踩坑

一、预告

本文不是一篇入门的文章所有请符合以下条件的战斗人员绕道:

1、初学前端,对前端的传统布局还不是很熟悉的人

2、后端人员对前端不打算深入学习的同学

 

二、开篇

flex布局原本是好几个月前就一直想学习的东西,当时flex布局还算是比较新鲜的玩意,转眼间flex布局已经不再新鲜,而且这些年,随着浏览器对ES6的支持情况日益增强,使得我们越来越有必要去学习一下怎样去使用好flex布局,废话我也就不多说了,我们就直奔主题吧

 

三、何为flex

 说到什么是flex这里就引用以下阮一峰老师的定义

布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性。它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。

我认为flex布局最大的优势就是在其的“弹性”,“弹性”主要表现在flex布局不同于盒子模型的百分比布局和CSS3支持的响应式布局,以下有几种情况是盒子模型中的这些布局所不便实现的:

1、浏览器的视口空间不足,要求视口中的特定块要按照比例进行缩放

2、应对一些布局是要以基准线(baseline)对齐的特殊布局方法

3、需要模块垂直居中

从应对一些特殊布局上来说,使用flex确实比盒子模型的布局更是一种更优的解决方案

 

四、flex布局的基本语法回顾

 flex布局的语法比较的简单,首先我们需要在父节点定义一个

display:flex;

接着我们可以对整个flex进行子节点设置,来设置主轴上的子节点的排列顺序

flex-direction:column || row || column-reverse || row-reverse

但是这个时候主轴上面的每个节点(item),默认都是紧贴在一起的要么靠左要么靠右(flex-direction:row or flex-direction:row-reverse,且默认的justify-content:flex-start),所以我们需要通过justify-content来设置主轴上的item之间的排列方式

justify-content:flex-start | flex-end | center | space-between | space-around;

除了可以在主轴上面控制横向布局,还可以控制主轴上的元素的纵向布局

 align-items:flex-start || flex-end || center || baseline || stretch

上面说到的是单轴线的问题,但是flex布局不但可以解决单轴上面的布局,还可以解决多轴线上面的布局

align-content:flex-start || flex-end || stretch|| center || space-between || space-around

这个时候如果是有某个item需要重新调整布局的话,我们可以使用align-self:

align-self: auto | flex-start | flex-end | center | baseline | stretch;

除了这个属性还有flex这个属性,这个是用来定义item的百分比以及缩放的,其他的一些属性就不在这个一一列举:具体详见

Flex 布局教程:语法篇

 

五、一些flex的典型案例与坑

 1、随着flex-direction的改变,其他的一些属性也跟着改变

改变前的代码是:

<div style="height: 400px;width: 400px;border:1px solid black;display: flex;justify-content: center;"><div style="flex: 0 0 30%;background: red"></div><!-- <div style="float: left"></div> --></div>

 

运行的结果是:

图一

改变一下flex-diirection后,代码如下:

<div style="height: 200px;width: 400px;border:1px solid black;display: flex;justify-content: center;flex-direction: column;"><div style="flex: 0 0 30%;background: red"></div><!-- <div style="float: left"></div> --></div>

图二

上面的这个小例子告诉我们,其实在应用flex的时候,我们应该要注意一下justify-content,align-content,align-items这些属性是相对于主轴的位置来定义的,flex-direction的属性发生了变化,也就是主轴的位置发生了变化,自然这些属性也发生了改变(例如上面的justify-content是水平居中的,但是主轴flex-direction:column设置之后,就是垂直居中)

 

2、flex的子元素不受float的影响

<div style="height: 200px;width: 400px;border:1px solid black;display: flex;justify-content: center;"><div style="flex: 0 0 30%;background: red;height:30%;float: right"></div></div>

效果参照图1

 

3、不能在display中嵌套absolute、relative,这样布局会失效

<div style="height: 200px;width: 400px;border:1px solid black;display: flex;justify-content: center;"><div style="width: 380px;height: 180px"><div style="flex: 0 0 30%;background: red;height:30%;"></div></div></div>

 运行效果如下:

 

4、flex-wrap的默认是nowrap,我们需要设置才回自动换行

<div style="height: 200px;width: 400px;border:1px solid black;display: flex;justify-content: center;"><div style="flex: 0 0 30%;background: red;height:30%;"></div><div style="flex: 0 0 30%;background: red;height:30%;"></div><div style="flex: 0 0 30%;background: red;height:30%;"></div><div style="flex: 0 0 30%;background: red;height:30%;"></div></div>

运行效果如下:

 

六、flex布局使用注意事项

flex布局的兼容性不是太好,至少某些低版本的安卓机上面是不能够识别改布局的,但是总体上随着浏览器对H5属性的支持程度的提升,以及一些老式的安卓手机的淘汰,目前该布局在手机上面还是有比较好的应用的,但是在使用flex布局的同时,建议还是要搭配上gulp或者是grunt等自动化的工具来进行浏览器前缀的编译,这样一方面可以节约手动的去添加浏览器的兼容性前缀,另外的一方面是可以解觉手机上面不同浏览器的差异导致的问题,一般来说flex布局就是在手机上面使用的,在PC上面由于需要考虑到IE的支持程度的问题,所以在PC上面还是不宜去使用flex。

转载于:https://www.cnblogs.com/st-leslie/p/6493224.html

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

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

相关文章

RT-Thread I/O设备模型

I/O设备指的是嵌入式系统中的一些Input输入/Output输出设备&#xff0c;输入输出设备是嵌入式系统重要的组成部分。输入和输出设备可以看做是计算机系统和外界进行沟通的桥梁&#xff0c;因此在计算机组成原理中输入输出设备是重要的组成部分。 计算机组成原理中的5大组成部分…

如何使用易我数据恢复向导恢复数码相机删除的图片

1 使用"易我数据恢复向导"的高级恢复(务必将数码相机的存储卡取出单独插入SD卡槽,而不是直接用数据线连接到电脑上,这样存储卡才能以磁盘方式显示) 2 选中对应磁盘,点击下一步 3 如果出现"分区参数不正确"提示&#xff0c;直接取消即可开始搜索 4 搜索完…

RT-Thread对GPIO操作两种方式的区别:1)通过设备操作接口2)直接通过通用GPIO设备驱动

在学习RT-Thread设备驱动框架时&#xff0c;看到潘多拉开发板的RT-Thread例程资料中的文档《AN0002-RT-Thread-通用 GPIO 设备应用笔记》有如下描述&#xff0c;因此产生使用文档中未使用的方式1&#xff09;通过设备操作接口 方法实现GPIO操作的想法&#xff01; 使用潘多拉开…

英语----情态动词(下)

should 应该 竟然 Youd should go to school right now. I should help him. How should i know. Im surprised tha he that he should be so rude to you. it worries me its a pity. You cant imagine.... ought to // 用在比较严肃的场合 You ought to take car…

清华大学-曾鸣-《ARM微控制器与嵌入式系统》I2C总线(一)

I2C是一种双向2线制同步串行通讯接口&#xff0c;是一类非常经典的串行总线通讯&#xff0c;理解好I2C通讯会帮助理解USB通讯、以太网通讯中的握手、数据帧等环节。 I2C的发展历史&#xff1a; SPI串行通讯主要是由MOTOROLA公司提出的&#xff0c;MOTOROLA公司的半导体部门独立…

清华大学-曾鸣-《ARM微控制器与嵌入式系统》I2C总线(二)

I2C&#xff08;Inter IC Bus&#xff09;的通讯数据帧&#xff1a; SCL线无方向区分&#xff0c;SDA线上有数据的流动方向。上图中灰色的代表的是主机向从机发送数据&#xff0c;此时SDA线的电平控制权由主机掌控&#xff0c;从机只能监听该线上的电平状态。白色代表的是从机向…

window.open 和showModalDialog的返回值

方法&#xff1a; 1: 在父级页面 test.aspx 的点击<input type"button" id"btnShow" οnclick"showItem();" value"显示子窗体"/>按钮触发 &#xff0c;然后 &#xff1a; <script language"JavaScript" type&qu…

RT-Thread I2C设备驱动框架的对接使用

I2C和SPI是MCU和板载芯片之间最常用的通讯方式&#xff0c;现在先介绍下I2C总线。I2C的基本原理也很简单&#xff0c;只需要两根线&#xff08;时钟线SCL和信号线SDA&#xff09;即可实现挂载在I2C总线上设备之间的相互通讯。I2C协议并未规定I2C总线上哪个是主机&#xff1f;哪…

给lnmp一键包中的nginx安装openresty的lua扩展

lnmp一键包&#xff08;https://lnmp.org&#xff09;本人在使用之后发现确实好用&#xff0c;能帮助我们快速搭建起lnmp、lamp和lnmpa的web生产环境&#xff0c;因此推荐大家可以多试试。但有的朋友可能需要使用openresty的lua扩展&#xff0c;这篇文章就会教你们怎么在军哥的…

RT-Thread 简介及架构

RT-Thread&#xff0c;全称是 Real Time-Thread&#xff0c;顾名思义&#xff0c;它是一个嵌入式实时多线程操作系统&#xff0c;基本属性之一是支持多任务&#xff0c;允许多个任务同时运行并不意味着处理器在同一时刻真地执行了多个任务。事实上&#xff0c;一个处理器核心在…

Linux中通过Socket文件描述符寻找连接状态介绍

针对下文的总结&#xff1a;socket是一种文件描述符 进程的打开文件描述符表 Linux的三个系统调用&#xff1a;open&#xff0c;socket&#xff0c;pipe 返回的都是一个描述符。不同的进程中&#xff0c;他们返回的描述符可以相同。那么&#xff0c;在同一个进程中&#xff0c;…

iOS HTML标签字符实体,转译字符串归类大全 【转载】

为什么要用转义字符串&#xff1f; HTML中<&#xff0c;>&#xff0c;&等有特殊含义&#xff08;<&#xff0c;>&#xff0c;用于链接签&#xff0c;&用于转义&#xff09;&#xff0c;不能直接使用。这些符号是不显示在我们最终看到的网页里的&#xff0c…

RT-Thread在github上的教程中图片显示不出来问题的解决方法

在github上查看RT-Thread STM32系列BSP制作教程时发现教程中所有的图片都加载不出来&#xff0c;非常影响教程的阅读使用。 使用记事本打开文件&#xff1a; C:\Windows\System32\drivers\etc\hosts 将如下内容复制粘贴到hosts文件末尾&#xff1a; # GitHub Start 140.82.11…

贝叶斯原理及其推断简介

1、贝叶斯公式及应用&#xff1a; 详见&#xff1a;链接ruanyifeng.com/blog/2011/08/bayesian_inference_part_one.html 转载于:https://www.cnblogs.com/1995hxt/p/6527604.html

在STM32CubeMX生成的MDK5工程上添加RT-Thread Nano后双击工程名无法打开.map文件的解决方法

当我们基于STM32CubeMx完成芯片的基础配置&#xff0c;再将RT-Thread Nano添加到工程编译完成之后。双击工程名称发现无法打开工程的.map文件&#xff0c;.map文件是STM32开发中非常重要的一个文件&#xff0c;map文件中详细描述了各个函数在ROM中的存储地址和大小&#xff0c;…

Oracle trunc()函数的用法

1、取当年的第一天和当年的最后一天 select trunc(sysdate,YYYY),add_months(trunc(sysdate,YYYY),12)-1 from dual tselect to_char(trunc(add_months(last_day(sysdate), -1) 1), yyyy-mm-dd) "本月第一天", to_char(last_day(sysdate), yyyy-mm-dd) "本月最…

STM32实现USB虚拟串口原理(下)

中断传输应用如主机定期间隔送鼠标读取当前的输入信息&#xff0c;或键盘的输入键值 同步传输应用于音视频等对延迟有严格要求的场合 大容量传输对实时性没有太高要求&#xff0c;对延迟有较大的容忍&#xff0c;且在协议层面并未规定最大的容忍延迟时间&#xff0c;但能从协议…

js下载

下载用ajax不好使,得用表单提交的方式 download:function(url,paramObj){var doc document;//使用一个隐藏的form表单执行提交&#xff0c;没有则创建var downloadForm doc.getElementById(_downloadForm);if(!downloadForm){downloadForm doc.createElement(form);download…

RT-Thread中堆和栈内存的分配

在嵌入式软件开发中&#xff0c;我们经常会提到堆和栈&#xff0c;实际上堆和栈都是RAM上的物理内存空间&#xff0c;只是使用方式不同而已。栈和堆都是单片机RAM中一段连续的存储空间&#xff0c;该段空间一般在启动文件或链接脚本中指定&#xff0c;最后在C库的_main函数中进…

RT-Thread Nano版本和RT-Thread Master版本的关系

RT-Thread Nano版本和RT-Thread Master版本的关系&#xff1a; RT-Thread Master版本不仅仅是一个实时内核&#xff0c;还包含了丰富的中间层组件。 RT-Thread Nano是RT-Thread Master之上进行剪裁后形成的精简版&#xff0c;去掉了一些组件和各种开发板的BSP&#xff0c;仅保…