CSS基础:浅聊flex布局以及常用属性

2024-06-18 21:18

本文主要是介绍CSS基础:浅聊flex布局以及常用属性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

导语

流式布局,这个很简单也很容易理解,就是从上而下根据布局,然后依次通过元素进行布局即可,和web前面聊的网页开发没有什么大的区别,现在现在聊了一些flex布局,这个让流式布局中的一些布局进行优化。

借鉴一个网络途牛首页先看一下:

在这里插入图片描述

然后看一下其CSS源码:

在这里插入图片描述

一般为什么再pc端比移动版网页版要晚一些才能被广泛使用呢?因为这个需要新版本的浏览器才可以支持,而移动端前面也聊过对于兼容性要求相对要低。所以在移动端使用比pc端更加早以及广泛。

还是老规矩开始整代码演示,对于理论我不太喜欢阐述,而是先看代码效果,然后就明白其存在的牛逼之处。

体验

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8">
<!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{width: 800px;height: 600px;background-color: #4a90e2;}.box1{display: flex;}span{width: 200px;height: 200px;background-color: #55a532;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span>
</div>
</body>
</html>

在这里插入图片描述

如果这样看,就是简单一个赋予了子元素变成块内行元素而已啊,这个有什么可以吹的?浮动也可以啊,不就是在父类写了,然后子类浮动就不用在子元素中都写而已吗?

如果这样的话,那就是没有多少意义了。

如果添加一个属性呢?

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{width: 800px;height: 600px;background-color: #4a90e2;}.box1{display: flex;justify-content: space-around;}span{width: 200px;height: 200px;background-color: #55a532;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span>
</div>
</body>
</html>

在这里插入图片描述

flex 布局原理

flex(flexible box):弹性布局,用来为盒状模型提供最大的灵活性,任何一个容器都可以指定为flex布局。

注意:当我们为父类设为flex布局之后,子元素的float,clear和vertical-align属性失效。

所以说flex布局,用大白话说就是使用flex来进行页面布局。而这个属性是添加给父类盒子,来控制黑子的位置和排列方式。

flex布局中对父类常用的6个属性:

属性描述
flex-direction设置主轴的方向
justify-content设置主轴上子元素的排列方式
flex-wrap设置子元素是否换行
align-content设置侧轴上的子元素排列方式(多行)
align-items设置侧轴上的子元素排列方式(单行)
flex-flow复合属性,相当于flex-direction和flex-wrap

父类属性

flex设置主轴方向:flex-direction

在flex布局中分为主轴和侧轴两个方向,也可以叫做行和列,或者x轴y轴。简单的说就是横和竖,默认横着是主轴,但是通过flex-direction进行从新划分。

在这里插入图片描述

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{display: flex;width: 800px;height: 600px;background-color: #4a90e2;}.box1{flex-direction: column ;}.box3{flex-direction: row-reverse ;}span{width: 200px;height: 200px;background-color: #55a532;margin-left: 5px;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box3"><span>1</span><span>2</span><span>3</span>
</div>
</body>
</html>

在这里插入图片描述

flex 设置主轴上子元素的排列:justfy-content

这个就使用到了justify-content属性:

在这里插入图片描述

在使用的之前一定要确定那个是主轴,不然就与自己想象中的结果有偏移,上面说的有些啰嗦,我简单是说一下:

属性值描述
flex-start默认值 从头部开始,主轴为x从左到右,主轴为y轴从上而下
flex-end从尾部来时列,与flex-start向反
center在主轴居中对齐,x轴就是水平居中,而y轴就是上下居中
space-around平分剩余空间
space-between先两边贴边,再平分剩余空间。

演示的时候,直接为x轴为主轴,不在分别演示如果是y轴的时候是什么情况。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{display: flex;width: 800px;height: 200px;background-color: #4a90e2;}.box1{justify-content: flex-start;}.box2{justify-content: flex-end;}.box3{justify-content: center;}.box4{justify-content: space-around;}.box5{justify-content: space-between;}span{width: 200px;height: 200px;background-color: #55a532;margin-left: 5px;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box3"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box4"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box5"><span>1</span><span>2</span><span>3</span>
</div>
</body>
</html>

在这里插入图片描述

flex的子元素是否换行 :flex-wrap

这个就使用到了flex-wrap这个属性。

具体如下:

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{margin-bottom: 500px;display: flex;width: 800px;height: 200px;background-color: #4a90e2;}.box1{flex-wrap: nowrap;}.box2{flex-wrap: wrap;}.box3{flex-wrap: wrap-reverse;}span{width: 300px;height: 200px;background-color: #55a532;margin-left: 5px;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box3"><span>1</span><span>2</span><span>3</span>
</div></body>
</html>

在这里插入图片描述

注意:flex布局中,默认子元素是 不换行的,如果不换行的话,而父类盒子装不下的话,就会缩小元素的宽度,放到父元素里面

单行控制侧轴的排序:align-items

前面可以通过justify-content属性,来控制主轴是否居中或者靠近后面等,自然不能满足我们的需求的是,还是需要控制侧轴的位置。

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{margin-bottom: 500px;display: flex;width: 800px;height: 600px;background-color: #4a90e2;justify-content: center;}span{width: 300px;height: 200px;background-color: #55a532;margin-right: 5px;}.box1{flex-wrap: nowrap;align-items: center;}.box2{flex-wrap: wrap;align-items: center;}.box3{/* 使用拉伸那子盒子就不能给高度了*/align-items: stretch;}.box3 span{width: 300px;/* 使用拉伸那子盒子就不能给高度了*/height: auto;background-color: #df5000;margin-right: 5px;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span><span>4</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span><span>4</span>
</div>
<hr />
<div class="box3"><span>1</span><span>2</span><span>3</span><span>4</span>
</div></body>
</html>

在这里插入图片描述

但是如果上图中第二个图,让四个盒子一起居中对齐呢,这样动画align就无法实现了,所以就需要一个多行的排序align-content

多行控制侧轴的排序:align-content

这个是多行的对齐:

在这里插入图片描述

其实这个说是多行这个应该和justfy-content相对应一个主轴一个侧轴。

设置子元素在侧轴排列方式,并且只能用于子元素出现换行(多行)的情况下,其在单行是没有效果的。

属性值描述
flex-start默认值 从头部开始,侧轴为x从左到右,侧轴为y轴从上而下
flex-end从尾部来时列,与flex-start向反
center在侧轴居中对齐,x轴就是水平居中,而y轴就是上下居中
space-around平分剩余空间
space-between先两边贴边,再平分剩余空间。

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{display: flex;flex-wrap: wrap;width: 800px;height: 600px;background-color: #4a90e2;}span{width: 300px;height: 200px;background-color: #55a532;margin-right: 5px;}.box1{align-content: flex-start;}.box2{align-content: flex-end;}.box3{align-content: center;}.box4{align-content: space-around;}.box5{align-content: space-between;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span><span>4</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span><span>4</span>
</div>
<hr />
<div class="box3"><span>1</span><span>2</span><span>3</span><span>4</span>
</div>
<hr />
<div class="box4"><span>1</span><span>2</span><span>3</span><span>4</span>
</div>
<hr />
<div class="box5"><span>1</span><span>2</span><span>3</span><span>4</span>
</div></body>
</html>

在这里插入图片描述

复合写法flex-flow

前面也说了flex-flow属性是flex-direction和flex-wrap属性的复合属性。

flex-flow:row wrap;

这个就不在演示比了,毕竟很容易理解就是一个复合写法而已。

子元素属性

flex后面加数字

flex后面添加一个数字就是占剩下的份数,而总分数就是子元素相加。简单演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{width: 800px;height: 600px;background-color: #4a90e2;}.box1{display: flex;}span{/* 可以看出这个宽度就意义了*/width: 200px;height: 200px;background-color: #55a532;margin-left: 5px;flex: 1;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div>
<hr />
<div class="box2"><span>1</span><span>2</span><span>3</span>
</div>
</body>
</html>

在这里插入图片描述

再来一个神奇是案例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{width: 800px;height: 600px;background-color: #4a90e2;}.box1{display: flex;}.box1 span:nth-child(1){width: 200px;height: 200px;background-color: #55a532;}.box1 span:nth-child(2){flex: 1;height: 200px;background-color: #f86262;}.box1 span:nth-child(3){width: 200px;height: 200px;background-color: #55a532;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div></body>
</html>

在这里插入图片描述

这个份数不一定非得是1:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{width: 800px;height: 600px;background-color: #4a90e2;}.box1{display: flex;}.box1 span:nth-child(1){flex: 1;height: 200px;background-color: #55a532;}.box1 span:nth-child(2){flex: 1;height: 200px;background-color: #f86262;}.box1 span:nth-child(3){flex: 3;height: 200px;background-color: #55a532;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div></body>
</html>

在这里插入图片描述

align-self

这个属性是控制子项目自己在侧轴的排列方式。

在这里插入图片描述

align-self控制子元素在侧轴上的排列方式,允许单个子元素与其它不应有对齐方式,可以覆盖align-items属性。默认是auto,表示继承父类的align-items属性,如果没有父元素,则等同于stretch。

里面属性意义就不再重复,和前面的意思一样,就演示要给。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{width: 800px;height: 600px;background-color: #4a90e2;}.box1{display: flex;}span{/* 可以看出这个宽度就意义了*/width: 200px;height: 200px;background-color: #55a532;margin-left: 5px;flex: 1;}span:nth-child(3){align-self: flex-end;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div></body>
</html>

在这里插入图片描述

order属性定义项目排列顺序

这个是定位中的z-index不一样的地方是,z-index的数值越大,显示谁,而order却是数值越小越是在前面。

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">--><title>测试文档</title><style>[class^="box"]{width: 800px;height: 600px;background-color: #4a90e2;}.box1{display: flex;}span{/* 可以看出这个宽度就意义了*/width: 200px;height: 200px;background-color: #55a532;margin-left: 5px;flex: 1;}span:nth-child(3){order: -1;}</style>
</head>
<body>
<div class="box1"><span>1</span><span>2</span><span>3</span>
</div></body>
</html>

在这里插入图片描述

这篇关于CSS基础:浅聊flex布局以及常用属性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1073078

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

零基础STM32单片机编程入门(一)初识STM32单片机

文章目录 一.概要二.单片机型号命名规则三.STM32F103系统架构四.STM32F103C8T6单片机启动流程五.STM32F103C8T6单片机主要外设资源六.编程过程中芯片数据手册的作用1.单片机外设资源情况2.STM32单片机内部框图3.STM32单片机管脚图4.STM32单片机每个管脚可配功能5.单片机功耗数据6.FALSH编程时间,擦写次数7.I/O高低电平电压表格8.外设接口

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

ps基础入门

1.基础      1.1新建文件      1.2创建指定形状      1.4移动工具          1.41移动画布中的任意元素          1.42移动画布          1.43修改画布大小          1.44修改图像大小      1.5框选工具      1.6矩形工具      1.7图层          1.71图层颜色修改          1

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页: