10.[前端开发-CSS]Day10-CSS的浮动和flex布局
一、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练习
一. 完成所有的代码
-
边框可以不做
二. 说出为什么需要清除浮动以及如何清除浮动
-
由于浮动元素脱离了标准流 变成了浮动元素 不再向父元素汇报高度 所以父元素计算高度时并没有将浮动元素的高度计算进来 而一般父元素的高度是由内容撑开的 不予设置高度 因此就造成了高度塌陷的问题 而解决高度塌陷的问题就叫做清除浮动
-
清除浮动的目的是为了让父元素子计算高度的时候把浮动子元素的高度计算进去
-
清除浮动的方法
-
给父元素增加固定高度 但是需要计算不方便
-
在父元素的最后一个元素下面增加一个空的块级子元素 但是增加了无意义的标签 违反了结构与样式分离的原则
-
给父元素添加一个伪元素(推荐)
.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>
<img
src=""
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