flex布局应用与踩坑

article/2025/6/28 4:06:16
一、预告

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

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。


http://chatgpt.dhexx.cn/article/0r8S8AqK.shtml

相关文章

前端面试+学习笔记(HTML+CSS+JavaScript+ES6+Vue+NodeJs)

前端面试学习笔记&#xff08;HTMLCSSJavaScriptES6VueNodeJs&#xff09; 一. HTML 1. 盒子模型 是什么&#xff1a;每个元素被表示为一个矩形的盒子&#xff0c;有四个部分组成&#xff1a;内容&#xff08;content&#xff09;、内边距&#xff08;padding&#xff09;、边…

ReactNative基础篇(1)语法、布局、组件通信

•1.1语法 •ES6语法&#xff1a;ECMAScript6.0&#xff08;以下简称ES6&#xff09;是JavaScript语言的下一代标准&#xff0c;已经在2015年6月正式发布了。它的目标&#xff0c;是使得JavaScript语言可以用来编写复杂的大型应用程序&#xff0c;成为企业级开发语言 •参考网…

HTML/CSS/JS 基本语法

前端 一、HTNL1、文件结构2、文本标签&#xff08;1&#xff09;块元素&#xff1a;div&#xff08;2&#xff09;行内元素&#xff1a;span&#xff08;3&#xff09;格式标签 3、图片、音频、视频&#xff08;1&#xff09;图片&#xff08;2&#xff09;音频< audio >…

flex 弹性布局

阮一峰的网络日志 首页 档案 上一篇&#xff1a;ES6 的功能侦测库 下一篇&#xff1a;Flex 布局教程&#xff1a;实 分类&#xff1a; 开发者手册 Flex 布局教程&#xff1a;语法篇 作者&#xff1a; 阮一峰 日期&#xff1a; 2015年7月10日 感谢 腾讯课堂NEXT学院 赞助本站&…

前端可能问到的面试题(ts,js,css,es6)

1.void,null,undefined&#xff0c;never,NaN void:无返回值&#xff0c;只能赋值undefined和null null:空值&#xff0c;表示不存在 undefined&#xff1a;未定义&#xff0c;声明了但没有赋值&#xff0c;对象没有赋值的属性&#xff0c;对象没有返回值 never&#xff1a;永…

利用es6和es5的继承方式写一个简单的弹窗

本片博文受到https://blog.csdn.net/zfzhuman123/article/details/90411793的启发,es6部分代码只改了一点点,逻辑也是遵照他的思想来的,而且es5继承的部分也是用了部分es6的语法 1.首先是index.html <!DOCTYPE html> <html lang"en"> <head><m…

Flex 布局教程:语法篇

阮一峰的网络日志 首页 档案 上一篇&#xff1a;ES6 的功能侦测库 下一篇&#xff1a;Flex 布局教程&#xff1a;实 分类&#xff1a; 开发者手册 Flex 布局教程&#xff1a;语法篇 作者&#xff1a; 阮一峰 日期&#xff1a; 2015年7月10日 网页布局&#xff08;layout&am…

Python全栈:ES6标准入门和Flex入门

文章目录 1 ES6标准入门2 开发环境搭建3 ES6与 JavaScript的关系4 ES6 变量与常量4.1 变量4.2 常量 5 ES6 解构赋值6 ES6 函数、箭头函数箭头函数理解this 7 JavaScript中的面向对象编程构造函数静态方法 8 ES6中的继承9 ES6中的模块化export的使用&#xff1a;import的使用在N…

ES6语法笔记

1.多行字符串 用反引号 表示&#xff1a; abc相当于 abc 2.字符串连接时使用变量 使用${变量名}直接引用字符串变量 var name 小明; var age 20; var message 你好, ${name}, 你今年${age}岁了!; alert(message); 3.字符串方法&#xff1a;不会改变原有字符串的内容&a…

mt4交易平台哪个好?不妨试试福瑞斯外汇平台

对于从事外汇交易的人来说&#xff0c;肯定对MT4不会陌生&#xff0c;众所周知&#xff0c;MT4是全球外汇交易中&#xff0c;最被广泛应用于零售客户市场的交易软件。界面简洁&#xff0c;容易上手等都是MT4潜在的优势&#xff0c;新手上路还得看MT4的指导。不过外汇交易中&…

AJPFX告诉你MT4平台有什么优势?

FX TERMINAL&#xff08;Meta Trader4&#xff09;交易平台功能 成功驾驭金融市场的第一步是拥有正确的工具。AJPFX为客户提供二十四小时的在线交易服务&#xff0c;MT4交易软件是目前全世界上最为先进&#xff0c;应用最为广泛的交易系统。客户的所要了解的行情报价&#xff0…

MT4行情交易API接口开发手记

之前开发的外汇量化交易系统&#xff0c;行情和交易接口都是通过在MT4平台下编写EA来实现&#xff0c;具体方法是&#xff1a;1、用C编写一个动态库文件&#xff0c;在里面实现行情和交易数据调用接口&#xff0c;将报价数据和K线数据写入数据库中&#xff0c;并从数据库中获取…

中期国际:MT4数据挖掘与分析方法:以数据为导向,制定有效的交易策略

在金融市场中&#xff0c;制定有效的交易策略是成功交易的关键。而要制定一份可靠的交易策略&#xff0c;数据挖掘与分析方法是不可或缺的工具。本文将介绍如何以数据为导向&#xff0c;利用MT4进行数据挖掘与分析&#xff0c;从而制定有效的交易策略。 首先&#xff0c;我们需…

双线macd指标参数最佳设置_手机mt4平台怎么使用macd双线指标

macd双线指标在外汇操作中具有重要作用&#xff0c;它既可用于电脑版的mt4&#xff0c;亦可用于手机mt4。那么&#xff0c;您对手机mt4macd双线指标了解多少&#xff1f;您知道它该如何添加、怎么使用吗&#xff1f;下文将为大家进行详细介绍。 手机mt4macd双线指标添加 手机mt…

MT4 API 跟单交易接口更新

1、MT4 API交易接口是什么&#xff1f; Api接口是跨平台多账号交易接口&#xff0c;是将MT4交易通道以API的方式聚合在一起&#xff0c;帮助开发商在各经纪商不提供manager后台账号、无须EA插件的情况下&#xff0c;也能轻松接入不同的MT4交易平台&#xff0c;完成登录、交易和…

MT4跟单软件更新至v4.23.0——HOOKSWORK多帐户跨平台

2022年12月7日更新内容&#xff1a; 1、新增“软件启动开始跟单” 当重启电脑或软件时&#xff0c;软件启动时&#xff0c;软件可自动启动开始按钮。 1&#xff09;重启服务器后自动登录系统命令&#xff1a;开始-运行- control userpasswords2 regedit>计算机\HKEY_LOCAL…

外汇交易MT4是什么软件?MT4与MT5有何区别?下载MT4要注意什么?

MT4是什么&#xff1f; MT4的全称是MetaTrader 4&#xff1b;是俄罗斯的迈达克公司发布的专门用于外汇交易的交易平台。MT4的特点是功能强大图表清晰使用简单&#xff1b;几乎可以加载市面上所有可用的金融市场技术分析指标&#xff1b;且自带mql语言功能&#xff1b;投资者甚至…

Hookswork多帐户跨平台MT4跟单软件的十二大优势:

Hookswork多帐户跨平台MT4跟单软件的十二大优势&#xff1a; 1、毫秒级跟单延迟 2、支持全球所有经纪商的 MT4 交易软件 3、不需要经纪商开放任何权限&#xff0c;不需要 EA 插件 4、不需要打开 MT4 终端 5、无绑定喊单及跟单账号数量限制 6、喊单账号也可以是观摩账号&#x…

中期国际:MT4交易平台介绍:功能、优势与适用范围

在外汇市场中&#xff0c;MetaTrader 4(简称MT4)被广泛认可为最受欢迎的交易平台之一。它具备丰富的功能和独特的优势&#xff0c;不仅适用于个人零售交易者&#xff0c;也广泛应用于金融机构和专业交易员。本文将介绍MT4交易平台的关键功能、独有优势以及适用范围。 首先&…

mt4系统平台的服务器,mt4平台服务器地址

mt4平台服务器地址 内容精选 换一换 Linux操作系统XEN实例变更为KVM实例前&#xff0c;必须已完成必要的驱动安装和配置。当您需要变更的Linux操作系统的XEN实例比较多时候&#xff0c;推荐您使用本节的批量自动配置的方法安装驱动&#xff0c;通过自动化脚本的方式批量为Linux…