參考文章:Flex 佈局教程:例項篇
一、骰子的佈局
- 骰子的一面,最多可以放置
9
個點。
data:image/s3,"s3://crabby-images/2ab13/2ab13f8168b56fbce3b86be17d584f2fd1688ffd" alt="CSS-Flex 佈局教程:例項篇"
下面,就來看看Flex
如何實現,從1
個點到9
個點的佈局。
data:image/s3,"s3://crabby-images/0c3f2/0c3f2994ad7958a95d29bd6e4da651a94a846f49" alt="CSS-Flex 佈局教程:例項篇"
如果不加說明,本節的HTML
模板一律如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!-- 頁面自動重新整理 -->
<meta http-equiv="refresh" content="1">
<title>Document</title>
<style>
* {
box-sizing: border-box;
}
html,
body {
height: 100%;
}
.box {
margin: 16px;
padding: 4px;
background-color: #e7e7e7;
width: 104px;
height: 104px;
object-fit: contain;
box-shadow:
inset 0 5px white,
inset 0 -5px #bbb,
inset 5px 0 #d7d7d7,
inset -5px 0 #d7d7d7;
border-radius: 10%;
/* flex容器屬性 */
display: flex;
}
.item {
display: block;
width: 24px;
height: 24px;
border-radius: 50%;
margin: 4px;
background-color: #333;
box-shadow: inset 0 3px #111, inset 0 -3px #555;
}
</style>
</head>
<body>
<div class="box">
<span class="item"></span>
<!-- <span class="item"></span> -->
</div>
</body>
複製程式碼
上面程式碼中,div
元素(代表骰子的一個面)是Flex
容器,span
元素(代表一個點)是Flex
專案。如果有多個專案,就要新增多個span
元素,以此類推。
1.1 單專案
- 首先,只有左上角
1
個點的情況。Flex
佈局預設就是首行左對齊,所以一行程式碼就夠了。
data:image/s3,"s3://crabby-images/5d37a/5d37a84366068d146e7ef50df4015e9a7070e9be" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
}
複製程式碼
- 設定專案的對齊方式,就能實現居中對齊和右對齊。
data:image/s3,"s3://crabby-images/40377/403770e4c1bc5f59af45fdf2712a1482689e8c7b" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
justify-content: center;
}
複製程式碼
data:image/s3,"s3://crabby-images/a5813/a5813db8fea1ff6d249886ef56173391a42dd083" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
justify-content: flex-end;
}
複製程式碼
- 設定交叉軸對齊方式,可以垂直移動主軸。
data:image/s3,"s3://crabby-images/08dc2/08dc29e8f25db23cd5f06fb51250010f2fecd9bf" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
align-items: center;
}
複製程式碼
data:image/s3,"s3://crabby-images/be989/be989013341aeabfe819cb3a370160f6355e9634" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
justify-content: center;
align-items: center;
}
複製程式碼
data:image/s3,"s3://crabby-images/2c906/2c90666cc63f504bc4933f1923dd400a547d4437" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
justify-content: center;
align-items: flex-end;
}
複製程式碼
data:image/s3,"s3://crabby-images/66281/662817a3515973ba6cb736bf8fbc6658fc0526c3" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
justify-content: flex-end;
align-items: flex-end;
}
複製程式碼
1.2 雙專案(先看容器佈局,在此基礎上移動專案佈局)
justify-content
data:image/s3,"s3://crabby-images/a0ec7/a0ec78a7b2dc6ab9767732d42effb291530f223d" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
justify-content: space-between;
}
複製程式碼
flex-direction
data:image/s3,"s3://crabby-images/119b4/119b4989e8db4010117b76dd7e86c3e8fa74885c" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
flex-direction: column;
justify-content: space-between;
}
複製程式碼
align-items
data:image/s3,"s3://crabby-images/11dff/11dffc4f5b1a66324510475d06d4b147ad5ca28a" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
flex-direction: column;
justify-content: space-between;
align-items: center;
}
複製程式碼
data:image/s3,"s3://crabby-images/f3e14/f3e14cb0b24b7a3709525791441d1b6dd1daa921" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
flex-direction: column;
justify-content: space-between;
align-items: flex-end;
}
複製程式碼
align-self
data:image/s3,"s3://crabby-images/78a51/78a513ac1f46afd5ad991c538f69fbe8fb7d56cc" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
}
.item:nth-child(2) {
align-self: center;
}
複製程式碼
data:image/s3,"s3://crabby-images/07460/074607071332dc99a4c7a2559af81ac5ba1dc780" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
justify-content: space-between;
}
.item:nth-child(2) {
align-self: flex-end;
}
複製程式碼
1.3 三專案
data:image/s3,"s3://crabby-images/03b2d/03b2d60305d8b3c4a175f02df13b437b9cdbb3fa" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
}
.item:nth-child(2) {
align-self: center;
}
.item:nth-child(3) {
align-self: flex-end;
}
複製程式碼
二、專案flex屬性
- 兩個快捷值:
auto (1 1 auto)
和none (0 0 auto)
(1)
data:image/s3,"s3://crabby-images/1e5b8/1e5b85590f1f53415537176135d40c107cde005a" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
}
.item {
flex: auto;
}
複製程式碼
(2)
data:image/s3,"s3://crabby-images/c9402/c9402255bb6b2eac0c039d78e67606c12b28f2e4" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
}
.item {
flex: none;
}
複製程式碼
(3)
data:image/s3,"s3://crabby-images/dc40a/dc40a55f8f8dc61481a64e5c3e2500ce9a8d3a3f" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
}
.item {
flex: 1; // 1 1 0%
}
複製程式碼
(4)
data:image/s3,"s3://crabby-images/93e21/93e219130702fe3810e8fc8ff58a3adcb6104763" alt="CSS-Flex 佈局教程:例項篇"
.box {
display: flex;
}
.item {
flex: 1;
}
.item:nth-child(1){
flex: 0 0 100%;
}
.item:nth-child(2){
flex: 0 0 50%;
}
複製程式碼