星期三的CSS-CSSBattle#73

更新於 2024/02/28閱讀時間約 7 分鐘

是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番!

很多大公司的切版與前端是分開的,但不能因為碰不到就不去理解,假如要系統性的調整樣式,那麼你就一定要懂基礎,就好像你要調整微前端的架構,總不能連包板工具的設定都不會吧!

回到正題,這系列文章每個禮拜三都會更新一題CSS Battle的題目,也歡迎想要學習或練習基礎切版的朋友們和我一起互動喔!

那麼我們這次從 #73 的問題來提供我的作法,那麼題目圖如下:

raw-image

我的思維邏輯

  1. 這次圖面稍微複雜一點,要用一點圖層堆疊的概念進行解構,我會先將耳朵與臉的部分做初步的分類。
  2. 我會考慮使用 grid 的方式來做底圖的排版,分別會是左耳、右耳與臉的三個主要的大項,然後臉的部分會透過 gridspan 2 來佔滿格數。
  3. 臉的部分也會分成三塊,分別是上面三角形的紋路、中間兩個眼睛及嘴巴(包含鼻字線條的白色部分)。

下面的 html 是按照上述幾個要點的結構

<div class="ear"></div>
<div class="ear"></div>
<div class="face">
<div class="stripe"></div>
<div class="eyes">
<div class="eye"></div>
<div class="eye"></div>
</div>
<div class="mouth">
<div class="nose"></div>
</div>
</div>

雖說複雜但透過上述的初步規劃,應該還是蠻容易理解的吧!那我們一樣先處理 body 的部分:

body {
margin: 0;
display: grid;
place-items: center;
place-content: center;
background: #F3AC3C;
grid-template: 0px 110px / 110px 110px;
}
.ear {
width: 40px;
height: 40px;
background: #1A4341;
border-radius: 50%;
border: 10px solid #998235;
}
.face {
width: 150px;
height: 150px;
background: #998235;
border-radius: 50% 50% 60px 60px;
grid-column: span 2;
overflow: hidden;
}

置中的處理我就不再贅述了,這次多加了一個 place-content: center; 主要是想讓每個網格裡的內容都往中間靠攏,至於 grid-template 後面的參數,可以透過預覽定位點慢慢微調找出來,包含臉部的輪廓 border-radius 的參數也是一樣,沒錯,每個調整都是試出來的,我們還是工程師,沒有通靈能力,也不會觀落陰。

做完上述的調整,我們開始來畫臉部的細節,如下:

.stripe {
width: 40px;
height: 40px;
background: #1A4341;
rotate: 45deg;
translate: 0px -23px;
margin: 0 auto;
}
.eyes {
display: flex;
justify-content: space-between;
align-items: center;
padding: 20px 25px 0 25px;
}
.eye {
background: #1A4341;
width: 20px;
height: 20px;
border-radius: 50%;
}
.mouth {
background: #FFFFFF;
height: 40px;
width: 100px;
border-radius: 20px 20px 50px 50px;
margin: 15px auto;
}
.nose {
background: #1A4341;
height: 30px;
width: 10px;
margin: 0 auto;
translate: 0 -10px;
}
.nose:before {
content: "";
display: block;
width: 20px;
height: 10px;
border: 10px solid #1A4341;
border-radius: 0px 0px 20px 20px;
border-top: 0px;
translate: -30px 20px;
}
.nose:after {
content: "";
display: block;
width: 20px;
height: 10px;
border: 10px solid #1A4341;
border-radius: 0px 0px 20px 20px;
border-top: 0px;
}

我就沒有再分段落貼CSS了,但原則上還是從上而下依序處理,最上面三角形的紋路我是透過旋轉和位移的方法來達成的。

眼睛的話可以分享一個小訣竅,在調整 padding 的時候我會多賦予它一個background 顏色,這樣會比較好確認訂位的參數。

鼻子線條的部分我是透過 before & after 的方式去加上綴飾線條,這部分就比較看個人,有的開發者習慣在拆的更多 span 去做組合也是可以。

技術總結

這題比起之前題目來的複雜許多,我提供的方法會比較偏向常用排版的延伸,主要也是希望能在日後的工作情境中使用,如果全部都用 position: absolute; 的方式來微調,一定也是可以達到 100%,但是我相信用這種方式處理的話,一般還是會直接請 UI 出張圖,那麼以上就是我的 100% 解法分享,一樣這題 100% 的解法絕對不會只有我這一種,大家也可以分享自己的作法與我交流,那麼我們下個禮拜三再見,Happy coding~ !

avatar-img
1會員
22內容數
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
Lee Luciano的沙龍 的其他內容
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 很多大公司的切版與前端是分開的,但不能因為碰不到就不去理解,假如要系統性的調整樣式,那麼你就一定要懂基礎,就好像你要調整微前端的架構,總不能連包板工具的設定都不會吧! 回到正題,這系列文章每個禮拜三都會更新一題CSS Battle的題
這篇文章分享了 CSS Battle #29 的解法,並提供了對於 grid、flex 和 nth-of-type 的使用技巧,讓讀者可以學習到基礎切版的相關知識。作者鼓勵讀者去分享自己的作法和進行交流。文章在每週三更新,歡迎有興趣的朋友參與互動。
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 很多大公司的切版與前端是分開的,但不能因為碰不到就不去理解,假如要系統性的調整樣式,那麼你就一定要懂基礎,就好像你要調整微前端的架構,總不能連包板工具的設定都不會吧! 回到正題,這系列文章每個禮拜三都會更新一題CSS Battle的題
是的,身為前端工程師的基本功! 還是需要時不時拿出來打磨一番,這系列文章每個禮拜三都會更新一題CSS Battle的題目,歡迎與我交流喔!
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 這系列文章每個禮拜三都會更新一題CSS Battle的題目與解法
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 這系列文章每個禮拜三都會更新一題CSS Battle的題目解法
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 很多大公司的切版與前端是分開的,但不能因為碰不到就不去理解,假如要系統性的調整樣式,那麼你就一定要懂基礎,就好像你要調整微前端的架構,總不能連包板工具的設定都不會吧! 回到正題,這系列文章每個禮拜三都會更新一題CSS Battle的題
這篇文章分享了 CSS Battle #29 的解法,並提供了對於 grid、flex 和 nth-of-type 的使用技巧,讓讀者可以學習到基礎切版的相關知識。作者鼓勵讀者去分享自己的作法和進行交流。文章在每週三更新,歡迎有興趣的朋友參與互動。
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 很多大公司的切版與前端是分開的,但不能因為碰不到就不去理解,假如要系統性的調整樣式,那麼你就一定要懂基礎,就好像你要調整微前端的架構,總不能連包板工具的設定都不會吧! 回到正題,這系列文章每個禮拜三都會更新一題CSS Battle的題
是的,身為前端工程師的基本功! 還是需要時不時拿出來打磨一番,這系列文章每個禮拜三都會更新一題CSS Battle的題目,歡迎與我交流喔!
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 這系列文章每個禮拜三都會更新一題CSS Battle的題目與解法
是的,身為前端工程師的基本功!還是需要時不時拿出來打磨一番! 這系列文章每個禮拜三都會更新一題CSS Battle的題目解法
你可能也想看
Google News 追蹤
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
那陣子的每週三下午,都是令我最期待的一刻。 上完半天的課程後,我火速回家,換個衣服,吃點簡單的午餐,拾起裝備,再衝回去與他們玩耍。
Thumbnail
華燈拍攝的年代,大約是我三、四年級的時候,當時好流行吹高角度,我覺得好漂釀🥰🥰🥰從小擁有實驗精神的我,吵著媽媽幫我買罐果凍髮膠、尖尾梳,利用星期三讀半天的下午,自己想辦法法吹出「夢幻高角度」。輕而易舉的,我破解了高角度的做法,每個星期三下午,我都讓自己頂著美美高角度,在家附近閒晃。 這一天,
週三又是三堂課的日子,早上在九如上活氧舒展(Jun)和熱血戰鼓(Alan),下午在博愛上熱力燃脂(Owen)。 相對靜態,又有練到平衡、肌力和伸展的活氧舒展,對我來說本季是替代樂活瑜珈的一堂課,音樂很好聽,上課很享受。今天有帶新動作,Jun說如果這動作讓屁股很酸,就要去上超能55,呵呵~我不由得會心
Thumbnail
被遺忘的《愛登士家庭》 在本公子的記憶中,跟《愛登士家庭》的初接觸應該是小學時期,曾在電視上看過一些片段。
Thumbnail
今天來聊聊復古作品的延伸新作《星期三》,即使不記得舊作故事,或許也記得經典的家族合照和片頭曲的第一小節!是個很抓眼球的作品
Thumbnail
雖然這幾天持續低溫特報,桃園觀音的風勢也特別大,但這一天孩子卻特別認真於課堂活動,讓老師覺得欣慰。
Thumbnail
「你知道我為什麼喜歡喝威士忌嗎?威士忌源自uisge beatha這,意指「生命之水」……給人生命與活力的水,那不是很美好嗎?」
Thumbnail
這個月開始,我參加了作家朋友帶領的線上讀書會,這一週,她以自己的著作《親愛的,你好》一書中的一篇文章〈我姓白,名老鼠〉為主題,讓大家以醫學這個傳統的權威角色,透過書寫來審視自己的權威議題。
Thumbnail
簡介: 七種不同人格在一個人體內輪流出現,一週中交換醒來。有一天,普通、沒有特別嗜好的星期二突然在星期三時醒來,他發現,星期三不見了。
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
那陣子的每週三下午,都是令我最期待的一刻。 上完半天的課程後,我火速回家,換個衣服,吃點簡單的午餐,拾起裝備,再衝回去與他們玩耍。
Thumbnail
華燈拍攝的年代,大約是我三、四年級的時候,當時好流行吹高角度,我覺得好漂釀🥰🥰🥰從小擁有實驗精神的我,吵著媽媽幫我買罐果凍髮膠、尖尾梳,利用星期三讀半天的下午,自己想辦法法吹出「夢幻高角度」。輕而易舉的,我破解了高角度的做法,每個星期三下午,我都讓自己頂著美美高角度,在家附近閒晃。 這一天,
週三又是三堂課的日子,早上在九如上活氧舒展(Jun)和熱血戰鼓(Alan),下午在博愛上熱力燃脂(Owen)。 相對靜態,又有練到平衡、肌力和伸展的活氧舒展,對我來說本季是替代樂活瑜珈的一堂課,音樂很好聽,上課很享受。今天有帶新動作,Jun說如果這動作讓屁股很酸,就要去上超能55,呵呵~我不由得會心
Thumbnail
被遺忘的《愛登士家庭》 在本公子的記憶中,跟《愛登士家庭》的初接觸應該是小學時期,曾在電視上看過一些片段。
Thumbnail
今天來聊聊復古作品的延伸新作《星期三》,即使不記得舊作故事,或許也記得經典的家族合照和片頭曲的第一小節!是個很抓眼球的作品
Thumbnail
雖然這幾天持續低溫特報,桃園觀音的風勢也特別大,但這一天孩子卻特別認真於課堂活動,讓老師覺得欣慰。
Thumbnail
「你知道我為什麼喜歡喝威士忌嗎?威士忌源自uisge beatha這,意指「生命之水」……給人生命與活力的水,那不是很美好嗎?」
Thumbnail
這個月開始,我參加了作家朋友帶領的線上讀書會,這一週,她以自己的著作《親愛的,你好》一書中的一篇文章〈我姓白,名老鼠〉為主題,讓大家以醫學這個傳統的權威角色,透過書寫來審視自己的權威議題。
Thumbnail
簡介: 七種不同人格在一個人體內輪流出現,一週中交換醒來。有一天,普通、沒有特別嗜好的星期二突然在星期三時醒來,他發現,星期三不見了。