前端HTML弹性布局display:flex的使用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>弹性布局</title>
<style type="text/css">
*{
margin: 0;
padding: 0;
}
.box{
width: 1100px;
margin: 30px auto;
border: solid 3px red;
/*开启弹性盒子*/
display: flex;
/*是否换行
wrap 换行*/
flex-wrap: wrap;
/*-----设置主轴方向 默认是主轴横向的且从左至右*/
/*row-reverse 横向反方向 要有宽度
column 纵向正方向 要有高度*/
/*flex-direction: row-reverse;*/
/*flex-direction: column;*/
/*设置主轴方向上的排布方式*/
/*justify-content: space-between;*/
justify-content: space-around;
/*--------------设置侧轴方向的排布方式-----------*/
/*假设主轴是横向的话,侧轴就是纵向的; 这就需要父标签有高度
并且父级高度大于子标签内容高度!!!*/
height: 450px;
/*baseline 以文字为基线对齐
以个体的行为布局*/
/*align-items: baseline;*/
/*align-items: flex-start;*/
/*整体的行布局*/
align-content: space-around;


}
.box div{
height: 200px;
width: 200px;
background-color: pink ;
/*margin-bottom: 20px;*/
}
.box div:nth-child(2n){
background-color: yellow;
}
.box div:nth-child(2){
/*margin-top: 20px;*/
/*padding: 20px;*/
}
/*--------------------------------------------------------*/
/*弹性子元素属性*/
/*调整某个弹性子盒子在几个位置显示*/
.box div:nth-child(3){
/*order: -1;*/
}
/*调整某个弹性子盒子在侧轴上的位置*/
.box div:nth-child(2){
/*align-self: flex-start;*/
/*flex: 1;*/
}
/**/
.box div:nth-child(4){

}
</style>
</head>
<body>
<div class="box">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
<div>5</div>
<div>6</div>
<div>7</div>
<div>8</div>
<div>9</div>
<div>10</div>
</div>
</body>
</html>
<!--
小结:
1.弹性属性给父级设置
2.弹性盒子内部默认是单行布局
3.一旦单行布局 字标签的宽度是无效的 会自动均分父级宽度
4.子标签不设置高度,默认参考父级高度
-->

运行结果:


前端HTML弹性布局display:flex的使用
http://ultracode.cn/2020/10/28/HTML/前端HTML弹性布局display:flex的使用/
作者
Win
发布于
2020年10月28日
许可协议