今天小編給大家分享一下怎么使用CSS Flex和Grid布局實現(xiàn)3D骰子的相關(guān)知識點,內(nèi)容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
成都創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供蒙陰網(wǎng)站建設(shè)、蒙陰做網(wǎng)站、蒙陰網(wǎng)站設(shè)計、蒙陰網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、蒙陰企業(yè)網(wǎng)站模板建站服務(wù),十年蒙陰做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
首先,來定義骰子六個面的 HTML 結(jié)構(gòu):
下面來實現(xiàn)每個面和每個點的的基本樣式:
.dice { width: 200px; height: 200px; padding: 20px; background-color: tomato; border-radius: 10%; } .dot { display: inline-block; width: 50px; height: 50px; border-radius: 50%; background-color: white; }
實現(xiàn)效果如下:
(1)一個點
HTML 結(jié)構(gòu)如下:
實現(xiàn)第一個面,只需要讓它水平和垂直方向都居中即可:
justify-content:center:使點與主軸(水平)的中心對齊。
align-items:center:使點與交叉軸(垂直)的中心對齊。
代碼實現(xiàn)如下:
.first-face { display: flex; justify-content: center; align-items: center; }
現(xiàn)在第一面是這樣的:
(2)兩個點
HTML 結(jié)構(gòu)如下:
首先來將第二個面的父元素設(shè)置為flex布局,并添加以下屬性:
justify-content: space-between:將子元素放置在 flex 容器的開頭和結(jié)尾。
.second-face { display: flex; justify-content : space-between; }
現(xiàn)在點的位置如下:
這時,第一個點在正確的位置:左上角。而第二個點需要在右下角。因此,下面來使用 align-self 屬性單獨調(diào)整第二個點的位置:
align-self: flex-end:將項目對齊到 Flex 容器的末尾。
.second-face .dot:nth-of-type(2) { align-self: flex-end; }
現(xiàn)在第二面是這樣的:
(3)三個點
HTML 結(jié)構(gòu)如下:
可以通過在第二面放置另一個中心點來實現(xiàn)第三面。
align-self: flex-end:將項目對齊到 Flex 容器的末尾。
align-self: center:將項目對齊到 Flex 容器的中間。
.third-face { display: flex; justify-content : space-between; } .third-face .dot:nth-of-type(2) { align-self: center; } .third-face .dot:nth-of-type(3) { align-self: flex-end; }
現(xiàn)在第三面是這樣的:
如果想要第一個點在右上角,第三個點在左下角,可以將第一個點的 align-self 更改為 flex-end,第二個點不變,第三個點無需設(shè)置,默認在最左側(cè):
.third-face { display: flex; justify-content : space-between; } .third-face .dot:nth-of-type(1) { align-self :flex-end; } .third-face .dot:nth-of-type(2) { align-self :center; }
現(xiàn)在第三面是這樣的:
(4)四個點
HTML 結(jié)構(gòu)如下:
在四個點的面中,可以將其分為兩行,每行包含兩列。一行將在 flex-start ,另一行將在 flex-end 。并添加 justify-content: space-between 以便將其放置在骰子的左側(cè)和右側(cè)。
.fourth-face { display: flex; justify-content: space-between }
接下來需要對兩列點分別進行布局:
將列設(shè)置為flex布局;
將flex-direction設(shè)置為column,以便將點放置在垂直方向上
將justify-content設(shè)置為space-between,它將使第一個點在頂部,第二個點在底部。
.fourth-face .column { display: flex; flex-direction: column; justify-content: space-between; }
現(xiàn)在第四面是這樣的:
(5)五個點
HTML 結(jié)構(gòu)如下:
第五面和第四面的差異在于多了中間的那個點。所以,可以基于第四面,來在中間增加一列,樣式如下:
.fifth-face { display: flex; justify-content: space-between } .fifth-face .column { display: flex; flex-direction: column; justify-content: space-between; }
現(xiàn)在第五面是這樣的:
還需要對中間的點進行調(diào)整,可以設(shè)置 justify-content 為 center 讓它垂直居中:
.fifth-face .column:nth-of-type(2) { justify-content: center; }
現(xiàn)在第五面是這樣的:
(6)六個點
HTML 結(jié)構(gòu)如下:
第六個面的布局和第四個幾乎完全一樣,只不過每一列多了一個元素,布局實現(xiàn)如下:
.sixth-face { display: flex; justify-content: space-between } .sixth-face .column { display: flex; flex-direction: column; justify-content: space-between; }
現(xiàn)在第六面是這樣的:
骰子每個面其實可以想象成一個 3 x 3 的網(wǎng)格,其中每個單元格代表一個點的位置:
+---+---+---+
| a | b | c |
+---+---+---+
| d | e | f |
+---+---+---+
| g | h | i |
+---+---+---+
要創(chuàng)建一個 3 x 3 的網(wǎng)格,只需要設(shè)置一個容器元素,并且設(shè)置三個大小相同的行和列:
.dice { display: grid; grid-template-rows: 1fr 1fr 1fr; grid-template-columns: 1fr 1fr 1fr; }
這里的 fr 單位允許將行或列的大小設(shè)置為網(wǎng)格容器可用空間的一部分,這上面的例子中,我們需要三分之一的可用空間,所以設(shè)置了 1fr 三次。
我們還可以使用 repeat(3, 1fr) 將 1fr 重復(fù) 3 次,來代替 1fr 1fr 1fr。還可以使用定義行/列的grid-template速記屬性將上述代碼進行簡化:
.dice { display: grid; grid-template: repeat(3, 1fr) / repeat(3, 1fr); }
每個面所需要定義的 HTML 就像是這樣:
所有的點將自動放置在每個單元格中,從左到右:
現(xiàn)在我們需要為每個骰子值定位點數(shù)。開始時我們提到,可以將每個面分成 3 x 3 的表格,但是這些表格并不是每一個都是我們需要的,分析骰子的六個面,可以發(fā)現(xiàn),我們只需要以下七個位置的點:
+---+---+---+
| a | | c |
+---+---+---+
| e | g | f |
+---+---+---+
| d | | b |
+---+---+---+
我們可以使用grid-template-areas屬性將此布局轉(zhuǎn)換為 CSS:
.dice { display: grid; grid-template-areas: "a . c" "e g f" "d . b"; }
因此,我們可以不使用傳統(tǒng)的單位來調(diào)整行和列的大小,而只需使用名稱來引用每個單元格。其語法本身提供了網(wǎng)格結(jié)構(gòu)的可視化,名稱由網(wǎng)格項的網(wǎng)格區(qū)域?qū)傩远x。中間列中的點表示一個空單元格。
下面來使用grid-area屬性為網(wǎng)格項命名,然后,網(wǎng)格模板可以通過其名稱引用該項目,以將其放置在網(wǎng)格中的特定區(qū)域中。:nth-child()偽選擇器允許單獨定位每個點。
.dot:nth-child(2) { grid-area: b; } .dot:nth-child(3) { grid-area: c; } .dot:nth-child(4) { grid-area: d; } .dot:nth-child(5) { grid-area: e; } .dot:nth-child(6) { grid-area: f; }
現(xiàn)在六個面的樣式如下:
可以看到,1、3、5的布局仍然是不正確的,只需要重新定位每個骰子的最后一個點即可:
.dot:nth-child(odd):last-child { grid-area: g; }
這時所有點的位置都正確了:
對于上面的 CSS,對應(yīng)的 HTML分別是父級為一個p標(biāo)簽,該面有幾個點,子級就有幾個span標(biāo)簽。代碼如下:
整體的 CSS 代碼如下:
.dice { width: 200px; height: 200px; padding: 20px; background-color: tomato; border-radius: 10%; display: grid; grid-template: repeat(3, 1fr) / repeat(3, 1fr); grid-template-areas: "a . c" "e g f" "d . b"; } .dot { display: inline-block; width: 50px; height: 50px; border-radius: 50%; background-color: white; } .dot:nth-child(2) { grid-area: b; } .dot:nth-child(3) { grid-area: c; } .dot:nth-child(4) { grid-area: d; } .dot:nth-child(5) { grid-area: e; } .dot:nth-child(6) { grid-area: f; } .dot:nth-child(odd):last-child { grid-area: g; }
上面我們分別使用 Flex 和 Grid 布局實現(xiàn)了骰子的六個面,下面來這將六個面組合成一個正方體。
首先對六個面進行一些樣式修改:
.dice { width: 200px; height: 200px; padding: 20px; box-sizing: border-box; opacity: 0.7; background-color: tomato; position: absolute; }
定義它們的父元素:
.dice-box { width: 200px; height: 200px; position: relative; transform-style: preserve-3d; transform: rotateY(185deg) rotateX(150deg) rotateZ(315deg); }
其中,transform-style: preserve-3d;表示所有子元素在3D空間中呈現(xiàn)。這里的transform 的角度不重要,主要是便于后面查看。
此時六個面的這樣的:
看起來有點奇怪,所有面都疊加在一起。不要急,我們來一個個調(diào)整位置。
首先將第一個面在 Z 軸移動 100px:
.first-face { transform: translateZ(100px); }
第一面就到了所有面的上方:
因為每個面的寬高都是 200px,所以將第六面沿 Z 軸向下調(diào)整 100px:
.sixth-face { transform: translateZ(-100px); }
第六面就到了所有面的下方:
下面來調(diào)整第二面,將其在X軸向后移動 100px,并沿著 Y 軸旋轉(zhuǎn) -90 度:
.second-face { transform: translateX(-100px) rotateY(-90deg); }
此時六個面是這樣的:
下面來調(diào)整第二面的對面:第五面,將其沿 X 軸的正方向移動 100px,并沿著 Y 軸方向選擇 90 度:
.fifth-face { transform: translateX(100px) rotateY(90deg); }
此時六個面是這樣的:
下面來調(diào)整第三面,道理同上:
.third-face { transform: translateY(100px) rotateX(90deg); }
此時六個面是這樣的:
最后來調(diào)整第五面:
.fourth-face { transform: translateY(-100px) rotateX(90deg); }
此時六個面就組成了一個完整的正方體:
下面來為這個骰子設(shè)置一個動畫,讓它轉(zhuǎn)起來:
@keyframes rotate { from { transform: rotateY(0) rotateX(45deg) rotateZ(45deg); } to { transform: rotateY(360deg) rotateX(45deg) rotateZ(45deg); } } .dice-box { animation: rotate 5s linear infinite; }
最終的效果如下:
以上就是“怎么使用CSS Flex和Grid布局實現(xiàn)3D骰子”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。