按下右側的「點擊預覽」按鈕能夠在當前頁面預覽,點擊連接能夠全屏預覽。css
https://codepen.io/comehope/pen/LBPvONhtml
此視頻是能夠交互的,你能夠隨時暫停視頻,編輯視頻中的代碼。前端
請用 chrome, safari, edge 打開觀看。git
https://scrimba.com/p/pEgDAM/cBEvpTLgithub
每日前端實戰系列的所有源代碼請從 github 下載:chrome
https://github.com/comehope/front-end-daily-challengesdom
定義 dom,容器中包含 4 個元素,分別表明光暈、火焰和燈芯:flex
<div class="candle"> <span class="glow"></span> <span class="flames"></span> <span class="thread"></span> </div>
居中顯示:spa
body { margin: 0; height: 100vh; display: flex; align-items: center; justify-content: center; background: black; }
畫出蠟燭的輪廓:code
.candle { width: 15em; height: 30em; font-size: 10px; background: linear-gradient( orange, darkorange, sienna, saddlebrown 50%, rgba(0, 0, 0, 0.6) ); box-shadow: inset 2em -3em 5em rgba(0, 0, 0, 0.4), inset -2em 0 5em rgba(0, 0, 0, 0.4); border-radius: 10em / 4em; }
用僞元素畫出蠟燭的頂面:
.candle { position: relative; } .candle::before { content: ''; position: absolute; width: inherit; height: 5em; border: 0.2em solid darkorange; border-radius: 50%; box-sizing: border-box; background: radial-gradient( #444, orange, saddlebrown, sienna, darkorange ); filter: opacity(0.7); }
畫出蠟燭的燈芯:
.candle { display: flex; justify-content: center; } .thread { position: absolute; width: 0.6em; height: 3.6em; top: -1.8em; background: linear-gradient( #111, black, orange 90% ); border-radius: 40% 40% 0 0; }
畫出蠟燭的內焰:
.flames { position: absolute; width: 2.4em; } .flames::before { content: ''; position: absolute; width: inherit; height: 6em; background-color: royalblue; top: -4.8em; border-radius: 50% 50% 35% 35%; border: 0.2em solid dodgerblue; box-sizing: border-box; filter: opacity(0.7); }
畫出蠟燭的外焰:
.flames::after { content: ''; position: absolute; width: inherit; height: 12em; top: -12em; background: linear-gradient(white 80%, transparent); border-radius: 50% 50% 20% 20%; box-shadow: 0 -0.6em 0.4em darkorange; }
畫出光暈:
.glow { position: absolute; width: 10em; height: 18em; background-color: orangered; border-radius: 50%; top: -16.5em; filter: blur(6em); }
爲外焰增長搖曳的效果:
.outer-flame { animation: enlarge 5s linear infinite, move 6s linear infinite; } @keyframes move { 0%, 100% { transform: rotate(-2deg); } 50% { transform: rotate(2deg); } } @keyframes enlarge { 0%, 100% { height: 12em; top: -12em; } 50% { height: 14em; top: -13em; } }
爲光暈增長閃爍效果:
.glow { animation: blink 100ms infinite; } @keyframes blink { to { filter: blur(6em) opacity(0.8); } }
最後,使蠟燭垂直居中:
.candle { top: 10em; }
大功告成!