這篇文章主要為大家展示了“如何使用純CSS實(shí)現(xiàn)一塊樂高積木”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“如何使用純CSS實(shí)現(xiàn)一塊樂高積木”這篇文章吧。
10年積累的網(wǎng)站設(shè)計制作、成都網(wǎng)站制作經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有平昌免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
代碼解讀
定義dom,容器中包含一組3個面:
<divclass="brick">
<divclass="sides">
<spanclass='front'></span>
<spanclass='right'></span>
<spanclass="top"></span>
</div>
</div>
居中顯示:
body{
margin:0;
height:100vh;
display:flex;
align-items:center;
justify-content:center;
background:radial-gradient(circleatcenter,white,skyblue);
}
定義容器尺寸:
.brick{
width:40em;
height:30em;
font-size:10px;
}
畫出積木的正面:
.brick{
position:relative;
}
.sides.front{
position:absolute;
width:9em;
height:6.8em;
background-color:#237fbd;
top:19em;
left:7em;
}
畫出積木的右面:
.sides>*{
position:absolute;
background-color:#237fbd;
}
.sides.right{
width:18em;
height:6.8em;
filter:brightness(0.8);
top:19em;
left:calc(7em+9em);
}
畫出積木的頂面:
.sides.top{
width:18em;
height:10.4em;
filter:brightness(1.2);
top:calc(19em-10.4em);
left:calc(7em+9em);
}
把以上3個面組合成立方體:
.sides.front{
transform-origin:right;
transform:skewY(30deg);
}
.sides.right{
transform-origin:left;
transform:skewY(-30deg);
}
.sides.top{
transform-origin:leftbottom;
transform:rotate(-60deg)skewY(30deg);
}
接下來畫積木的凸粒。
在dom中增加8個凸粒元素:
<divclass="brick">
<divclass="sides">
<spanclass='front'></span>
<spanclass='right'></span>
<spanclass="top"></span>
</div>
<divclass="studs">
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
</div>
</div>
定義變量:
.studsspan:nth-child(1){
--n:1;
}
.studsspan:nth-child(3){
--n:3;
}
.studsspan:nth-child(5){
--n:5;
}
.studsspan:nth-child(7){
--n:7;
}
.studsspan:nth-child(2){
--n:2;
}
.studsspan:nth-child(4){
--n:4;
}
.studsspan:nth-child(6){
--n:6;
}
.studsspan:nth-child(8){
--n:8;
}
畫出左側(cè)的凸粒:
.studsspan:nth-child(odd){
top:calc(4.6em+(var(--n)-1)/2*2.6em);
left:calc(23.3em-(var(--n)-1)/2*4.6em);
}
畫出右側(cè)的凸粒:
.studsspan:nth-child(even){
top:calc(6.9em+(var(--n)-2)/2*2.6em);
left:calc(27.9em-(var(--n)-2)/2*4.6em);
}
最后,畫出凸粒的頂面:
.studsspan::before{
content:'';
position:absolute;
width:inherit;
height:2em;
background-color:#4cb7ff;
border-radius:50%;
}
以上是“如何使用純CSS實(shí)現(xiàn)一塊樂高積木”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享文章:如何使用純CSS實(shí)現(xiàn)一塊樂高積木
網(wǎng)站路徑:http://vcdvsql.cn/article8/gjdjip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、小程序開發(fā)、網(wǎng)站策劃、網(wǎng)站改版、標(biāo)簽優(yōu)化、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)