10.[前端开发-CSS]Day10-CSS的浮动和flex布局

embedded/2025/2/2 23:14:38/

一、CSS的Flex布局

1 认识flex布局

认识flexbox

原先的布局存在的痛点

flex布局的出现

2 flex布局的理解

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>Document</title><style>.box {/* flex: 块级盒子的flex-container *//* inline-flex: 了解, 行内级盒子的flex-container */display: flex;background-color: #f00;}</style>
</head>
<body><!-- aaaa --><div class="box"><div class="item">1</div><div class="item">2</div><div class="item">3</div></div><!-- bbb --></body>
</html>

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>Document</title><style>.box {display: flex;background-color: #f00;flex-wrap: wrap;width: 200px;height: 200px;}.item {width: 60px;height: 60px;background-color: orange;}</style>
</head>
<body><!-- aaaa --><div class="box"><div class="item">1</div><div class="item">2</div><div class="item">3</div><div class="item">4</div><div class="item">5</div><div class="item">4</div><div class="item">5</div><div class="item">4</div><div class="item">5</div></div><!-- bbb --></body>
</html>

flex相关的属性
 

3 flex-container属性

flex-direction

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;/* 修改主轴的方向 *//* row-reverse: row的反转 *//* column: 列变成主轴的方向 *//* column-reverse: 列主轴进行反转 *//* flex-direction: column-reverse; */}.item {width: 120px;height: 120px;background-color: #f00;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

flex-wrap

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;/* nowrap: 默认值不换行 *//* flex-wrap: wrap; *//* flex-flow: wrap; */flex-flow: row-reverse wrap;}.item {width: 120px;height: 120px;background-color: #f00;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

flex-flow

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;/* flex-direction: row-reverse;flex-wrap: wrap-reverse; */flex-flow: row-reverse wrap-reverse;}.item {width: 120px;height: 120px;background-color: #f00;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

justify-content

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;/* padding: 0 10px; */box-sizing: border-box;display: flex;flex-wrap: wrap;/* 切换justify-content *//* flex-end: 让元素和main end对齐 *//* center: 居中对齐 *//* space-between: 两端个放一个元素, 其他多余的元素一定要空间等分 *//* space-evenly: 两端也有间距, 并且所有的空间进行等分 *//* space-around: 两端也有间距, 两端的间距是items之间的间距一半 */justify-content: space-between;}.item {width: 120px;height: 120px;background-color: #f00;/* margin-left: 20px; *//* margin: 0 20px; */}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div><div class="item item4">4</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

align-item

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;/* padding: 0 10px; */box-sizing: border-box;display: flex;align-items: stretch;}.item {width: 120px;/* height: 120px; */}.item1 {height: 80px;font-size: 30px;}.item2 {height: 150px;font-size: 40px;}.item3 {height: 60px;font-size: 12px;}</style>
</head>
<body><div class="container"><div class="item item1">1x</div><div class="item item2">2x</div><div class="item item3">3x</div><div class="item item4">4x</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

align-content

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;flex-wrap: wrap;justify-content: space-between;align-content: center;}.item {width: 120px;height: 120px;/* margin-bottom: 10px; */}</style>
</head>
<body><div class="container"><div class="item item1">1x</div><div class="item item2">2x</div><div class="item item3">3x</div><div class="item item4">4x</div><div class="item item2">2x</div><div class="item item3">3x</div><div class="item item4">4x</div><div class="item item2">2x</div><div class="item item3">3x</div><div class="item item4">4x</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

4 flex-item属性

flex-item属性 - order

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;}.item {width: 120px;height: 120px;}.item1 {order: 5;}.item2 {order: 3;}.item3 {order: 9;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

flex-item属性 - flex items

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;align-items: center;}.item {width: 120px;height: 120px;}.item1 {height: 90px;}.item2 {height: 150px;align-self: flex-start;}.item3 {height: 120px;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

flex-item属性 - flex-grow

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;}.item {width: 120px;height: 120px;flex-grow: 0;}.item1 {flex-grow: 1;max-width: 150px;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

flex-item属性 - flex-shrink

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;}.item {width: 120px;height: 120px;flex-shrink: 0;}.item1, .item2 {flex-shrink: 1;}.item1 {min-width: 100px;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div><div class="item item4">4</div><div class="item item5">5</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

flex-item属性 - flex-basis

<!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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;}.item {width: 120px;/* 基础尺寸 */flex-basis: 120px;height: 120px;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2我是coderwhy_why_hahahaha</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

flex-item属性 - 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>Document</title><style>.container {width: 500px;height: 500px;background-color: orange;display: flex;}.item {width: 120px;height: 120px;/* flex-grow flex-shrink flex-basis *//* none: 0 0 auto *//* auto: 1 1 auto */flex: 1 1 10px;}</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2我是coderwhy_why_hahahaha</div><div class="item item3">3</div></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

思考: 如下布局如何解决对其问题

<!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>Document</title><style>.container {width: 500px;background-color: orange;display: flex;flex-wrap: wrap;justify-content: space-between;}.item {width: 110px;height: 140px;/* margin-right: 20px; */}.container > i {width: 110px;}/* .item:nth-child(4n) {margin-right: 0;} */</style>
</head>
<body><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div><div class="item item1">1</div><div class="item item2">2</div><div class="item item3">3</div><div class="item item3">3</div><!-- 添加span的个数是列数减-2 --><i></i><i></i></div><script src="./js/itemRandomColor.js"></script>
</body>
</html>

二、Day10练习

一. 完成所有的代码

  • 边框可以不做

二. 说出为什么需要清除浮动以及如何清除浮动

  • 由于浮动元素脱离了标准流 变成了浮动元素 不再向父元素汇报高度 所以父元素计算高度时并没有将浮动元素的高度计算进来 而一般父元素的高度是由内容撑开的 不予设置高度 因此就造成了高度塌陷的问题 而解决高度塌陷的问题就叫做清除浮动

  • 清除浮动的目的是为了让父元素子计算高度的时候把浮动子元素的高度计算进去

  • 清除浮动的方法

    • 给父元素增加固定高度 但是需要计算不方便

    • 在父元素的最后一个元素下面增加一个空的块级子元素 但是增加了无意义的标签 违反了结构与样式分离的原则

    • 给父元素添加一个伪元素(推荐)

      css">.clear_fix::after {content: "";display: block;clear:both;visibility: hidden; /* 浏览器兼容性 */height: 0; /* 浏览器兼容性 */}
      .clear_fix {*zoom: 1; /* IE6/7兼容性 */
      }

三. 利用浮动完成如下布局结构(完成结构即可)(选做)

<!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>Document</title><style>.box {width: 1190px;margin: 0 auto;background-color: #f00;}.container {margin-right: -10px;}.item {float: left;width: 190px;height: 470px;background-color: #0f0;margin-right: 10px;}/* .item1,.item3 {} */.item2 {width: 590px;background-color: #00f;}.item3 {background-color: #fff;}.item3 .block {height: 150px;margin-bottom: 10px;background-color: #0f0;}.item3 .block:last-child {margin-bottom: 0;}</style></head><body><div class="box"><div class="container"><div class="item item1">1</div><div class="item item2">2</div><div class="item item3"><div class="block">3</div><div class="block">4</div><div class="block">5</div></div><div class="item item4">6</div></div></div></body>
</html>
​

四. 总结flex布局container和item的属性以及作用(重要)

  • container

    • flex-direction

      • 决定主轴(main axis)的方向(正方向或者反方向)有四个值

        • row(默认)

        • column 定义了主轴的方向和块轴排列的方向相同

        • row-reverse 与row的方向相反

        • column-reverse 与column的方向相反

    • flex-wrap

      • 定义了flex container是单行还是多行有如下值

        • nowrap(默认 不换行)

        • wrap(多行排列)

        • wrap-reverse 多行排列从下到上 与正常方向相反(不常用)

    • flex-flow

      • flex-direction与flex-wrap的缩写

    • align-items

      • 决定了items在纵横轴上的排布方式 值如下

        • baseline 与items的基线对齐

        • normal 在弹性布局中 效果和stretch 一样

        • center 居中对齐

        • flex-start 与cross start对齐

        • flex-end 与cross end 对齐

        • stretch 当items在cross axis的高度(默认为auto)为auto时 会自动拉伸至container的高度

    • justify-content

      • 决定了main axis方向上 flex items的对齐方式 值如下

      • center 居中对齐

      • flex-start 与main start对齐

      • flex-end 与main end对齐

      • space-between items之间的距离相等

      • space-around items之间的距离相等 items与main start 和main end之间的距离是 item与item之间距离的一半

      • space-evenly items之间的距离相等 items与main start 和main end之间的距离与 item与item之间的距离相等

    • align-content

      • 决定了items 在 cross axis上的对齐方式 用法与 justify-content相似

      • 只是由main方向 换成了 cross axis方向

  • item

    • flex-grow

      • grow 拉伸 可以设置任意非负数字(默认值是0)

      • 当item的宽度在main axis有剩余的size时 才会生效

      • 如果所有的items都有相同的 flex-grow 系数,那么所有的items将剩余空间按相同比例分配,否则将根据不同的 flex-grow 定义的比例进行分配。

      • 扩展后的最终size不能超过max-width/max-height

    • flex-shrink

      • shrink收缩 可以设置任意非负数字 只有当item size的盒超过了 contaienr的size时 才会生效)(默认值为1)

      • 如果

      • 收缩后的最终 size 不能小于 min-width\min-height

    • flex-basis

      • 用来设置item在主轴上的基本的size

      • item的优先级从高到低依次为

        • max/min-width/height

        • flex-basis

        • width/height

        • 内容本身的大小

      • 例外

        • 如果item内文字过长 会拉伸(没有设置width时无论实际宽度是否超出flex-basis的值)

    • align-self

      • 通过给某个flex item设置align-self,会对齐当前 grid 或 flex 行中的元素,并会覆盖align-items的设置。

    • order

      • 默认值是0 可以是任意整数 值越小排在前面

    • flex

      • flex-grow flex-shrink flex-basis的组合

      • none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
        ​
      • 可以使用一个,两个或三个值来指定 flex属性。

      • 一个值时

        • 数字 被当成flex-grow

        • 有效的宽度 被当成flex-basis

        • auto: 1 1 auto

        • none: 0 0 auto

      • 两个值时

        • 第一个值必须为无单位数 被当成flex-grow

        • 第二个值为无单位值时 被当成flex-shrink 有单位时 是 flex-basis

      • 三个值时 前两个为无单位值 最后一个为有单位宽度值 依次为 flex-grow flex-shrink flex-basis

五. 自己找3个案例练习

  • 案例一:其中用到元素定位

  • 案例二:其中用到浮动布局

  • 案例三:其中用到flex布局

  • 三合一(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>Document</title><style>body {background: url(https://img.alicdn.com/imgextra/i3/O1CN01PaQurJ1QgnAICTCgg_!!6000000002006-2-tps-1490-2984.png)repeat-y 0 36px;background-size: cover;overflow-x: hidden;}a {text-decoration: none;}
​.clearfix::after {content: " ";display: block;clear: both;
​visibility: hidden;height: 0;}.clearfix {*zoom: 1;}
​.box {width: 1200px;margin: 0 auto;height: 1000px;}.container {position: sticky;top: 0;margin-top: 60px;padding-top: 20px;}.container .tb-logo {float: left;width: 190px;
​margin-left: 32px;}
​.container .tb-logo .logo-bd {display: block;width: 148px;height: 0;padding-top: 58px;overflow: hidden;background: url(https://gw.alicdn.com/imgextra/i3/O1CN01uRz3de23mzWofmPYX_!!6000000007299-2-tps-143-59.png)no-repeat 0 0;}
​.container .tb-content {/* position: relative; */margin: 0 302px 0 255px;}.tb-content .search-bd {width: 728px;height: 38px;line-height: 38px;text-align: center;/* padding: 0 10px; */background-color: hsl(0deg 0% 100%);border: 2px solid hsl(19deg 100% 50%);border-radius: 50px;
​position: relative;}.search-bd .search-left {position: absolute;left: 10px;top: 0;height: 38px;font-size: 14px;}
​.tb-content [action] .search-icon {position: absolute;left: 60px;top: 7px;width: 1px;height: 24px;background: hsl(0deg 11% 95%);}.tb-content [action] .search-center {margin-left: 0px;margin-right: 75px;overflow: hidden;padding-left: 65px;}[action] .search-center > input {width: 100%;height: 20px;line-height: 20px;font-size: 14px;color: hsl(0deg 0% 0%);
​border: 0;outline: none;}.tb-content [action] .search-btn {position: absolute;top: 2px;right: 0;width: 72px;height: 34px;margin-right: 2px;overflow: hidden;border-radius: 20px;background-clip: padding-box;}.tb-content .search-btn > [type] {width: 72px;height: 34px;border: none;background: hsl(19deg 100% 50%);font-size: 18px;font-weight: 700;color: hsl(0deg 0% 100%);background-image: linear-gradient(to right,hsl(34deg 100% 50%) 0,hsl(19deg 100% 50%) 100%);background-repeat: repeat-x;cursor: pointer;}
​.container .tb-wrapper {position: absolute;top: 0;right: 58px;}.container .tb-wrapper > a {position: relative;display: block;text-align: center;width: 74px;height: 88px;color: hsl(0deg, 0%, 40%);border: 1px solid hsl(0deg, 0%, 93%);background-color: hsl(0deg, 0%, 100%);font-size: 12px;
​display: flex;flex-direction: column;justify-content: space-evenly;align-items: center;}
​.tb-wrapper a > img {width: 62px;height: 62px;}</style></head><body><div class="box"><div class="container"><div class="tb-logo clearfix"><a class="logo-bd" href="">淘宝网 </a></div>
​<div class="tb-content"><div class="search-bd"><div class="search-left">天猫</div><form action=""><i class="search-icon"></i><div class="search-center"><input type="text" placeholder="搜索" /></div><div class="search-btn"><button type="submit">搜索</button></div></form></div></div>
​<div class="tb-wrapper"><a href=""><span>下载淘宝</span><imgsrc=""alt=""/></a></div></div></div></body>
</html>
 

三、总结

二. flex布局

2.1. 认识flex布局

2.2. flex布局重要的概念

  • flex container

  • flex item

  • main axis/cross axios

  • main start/main end/cross start / cross end

2.3. flex container中的属性

  • flex-direction:

  • flex-wrap

  • flex-flow

  • justify-content

  • align-items

  • align-content

2.4. flex item中的属性

  • order

  • align-self

  • flex-grow

  • flex-shrink

  • flex-basis

  • flex

2.5. flex布局中justify-content最后一行布局问题


http://www.ppmy.cn/embedded/159034.html

相关文章

2502,dll导出C++类

C语言毕竟能和窗口DLL可和平共处. 介绍 自从窗口的开始阶段,动态链接库(DLL)就是窗口平台的一个组成部分.动态链接库,允许在一个独立的模块中封装一系列的功能函数,然后以一个显式的C函数列表供外部用户使用. 在上个世纪80年代,当窗口DLL面世时,对广大程序员而言只有C语言是…

深度学习篇---数据存储类型

文章目录 前言第一部分&#xff1a;C语言中的数据存储类型1. char&#xff08;通常是8位&#xff09;优点缺点 2. short&#xff08;通常是16位&#xff09;优点缺点 3. int&#xff08;通常是32位&#xff09;优点缺点 4. long&#xff08;通常是32位或64位&#xff09;优点缺…

如何移植ftp服务器到arm板子?

很多厂家提供的sdk&#xff0c;一般都不自带ftp服务器功能&#xff0c; 需要要发人员自己移植ftp服务器程序。 本文手把手教大家如何移植ftp server到arm板子。 环境 sdk&#xff1a;复旦微 Buildroot 2018.02.31. 解压 $ mkdir ~/vsftpd $ cp vsftpd-3.0.2.tar.gz ~/vs…

苹果AR眼镜:产品规划与战略路线深度解析

随着增强现实(AR)技术的不断发展,苹果公司正逐步推进其AR智能眼镜项目。尽管Vision Pro作为一款高端混合现实设备已经面世,但苹果真正的目标是开发出一款轻便、全天候佩戴且能够取代智能手机功能的AR眼镜。本文将梳理苹果在AR领域的探索历程,并分析其当前的产品状态及未来…

【机器学习】自定义数据集 使用scikit-learn中svm的包实现svm分类

一、支持向量机(support vector machines. &#xff0c;SVM)概念 1. SVM 绪论 支持向量机&#xff08;SVM&#xff09;的核心思想是找到一个最优的超平面&#xff0c;将不同类别的数据点分开。SVM 的关键特点包括&#xff1a; ① 分类与回归&#xff1a; SVM 可以用于分类&a…

[c语言日寄]越界访问:意外的死循环

【作者主页】siy2333 【专栏介绍】⌈c语言日寄⌋&#xff1a;这是一个专注于C语言刷题的专栏&#xff0c;精选题目&#xff0c;搭配详细题解、拓展算法。从基础语法到复杂算法&#xff0c;题目涉及的知识点全面覆盖&#xff0c;助力你系统提升。无论你是初学者&#xff0c;还是…

概述、 BGP AS 、BGP 邻居、 BGP 更新源 、BGP TTL 、BGP路由表、 BGP 同步

BGP&#xff08;Border Gatreway Protcol&#xff09;边界网关路由协议 BGP基本配置 BGP实战拓扑 外部BGP基础配置 内部BGP邻居 EBGP基本配置 CCNP综合实验拓扑 文章目录 系列文件概述BGP ASBGP 邻居BGP 更新源BGP TTLBGP路由表BGP 同步 概述 当前所使用的计算机网络…

29.Word:公司本财年的年度报告【13】

目录 NO1.2.3.4 NO5.6.7​ NO8.9.10​ NO1.2.3.4 另存为F12&#xff1a;考生文件夹&#xff1a;Word.docx选中绿色标记的标题文本→样式对话框→单击右键→点击样式对话框→单击右键→修改→所有脚本→颜色/字体/名称→边框&#xff1a;0.5磅、黑色、单线条&#xff1a;点…