談談一些有趣的CSS題目(一)-- 左邊豎條的實現方法


開本系列,討論一些有趣的 CSS 題目,拋開實用性而言,一些題目為了拓寬一下解決問題的思路,此外,涉及一些容易忽視的 CSS 細節。

解題不考慮兼容性,題目天馬行空,想到什么說什么,如果解題中有你感覺到生僻的 CSS 屬性,趕緊去補習一下吧。

不斷更新,不斷更新,不斷更新,重要的事情說三遍。

所有題目匯總在我的 Github 。

 

題目1、下面這個圖形,只使用一個標簽,可以有多少種實現方式:

假設我們的單標簽是一個 div:

<div></div>

定義如下通用CSS

div{
    position:relative;
    width:200px;
    height:60px;
    background:#ddd;
}

 

法一:border

這個應該是最最最容易想到的了

div{
    border-left:5px solid deeppink;
}

 

法二:使用偽元素

一個標簽,算上 before 與 after 偽元素,其實算是有三個標簽,這也是很多單標簽作圖的基礎,本題中,使用偽元素可以輕易完成。

div::after{
    content:"";
    width:5px;
    height:60px;
    position:absolute;
    top:0;
    left:0;
    background:deeppink;
}

 

法三:外 box-shadow

盒陰影 box-shadow 大部分人都只是用了生成陰影,其實陰影可以有多重陰影、單側陰影、陰影不可以不虛化,這就需要去了解一下 box-shaodw 的每一個參數具體作用。使用 box-shaodw 解題

div{
    box-shadow:-5px 0px 0 0 deeppink;
}

 

法四:內 box-shadow

盒陰影還有一個參數 inset ,用於設置內陰影,也可以完成:

div{
    box-shadow:inset 5px 0px 0 0 deeppink;
}

 

法五:drop-shadow

drop-shadow 是 CSS3 新增濾鏡 filter 中的其中一個濾鏡,也可以生成陰影,不過它的數值參數個數只有 3 個,比之 box-shadow 少一個。

div{
    filter:drop-shadow(-5px 0 0 deeppink);
}

 

法六:漸變 linearGradient

靈活使用 CSS3 的漸變可以完成大量想不到的圖形,CSS3 的漸變簡單而言分為線性漸變和徑向漸變,本題使用線性漸變,可以輕易解題:

div{
    background-image:linear-gradient(90deg, deeppink 0px, deeppink 5px, transparent 5px);
}

其實,CSS3 漸變遠不止線性漸變和徑向漸變,細分下來,還有重復線性漸變(repeating-linear-gradient)和重復徑向漸變(repeating-radial-gradient)以及已經被最新版本 Chrome 支持的圓錐漸變(conical-gradient),感興趣可以自行去學習一下。

 

法七:輪廓 outline

這個用的比較少,outline (輪廓)是繪制於元素周圍的一條線,位於邊框邊緣的外圍,可起到突出元素的作用。這個方法算是下下之選。

div{
    height:50px;
    outline:5px solid deeppink;
}
div::after{
    position:absolute;
    content:"";
    top:-5px;
    bottom:-5px;
    right:-5px;
    left:0;
    background:#ddd;
}

 

法八、滾動條

這個方法由 小火柴的藍色理想 提供,通過改變滾動條樣式實現:

div{
    width:205px;
    background:deeppink;
    overflow-y:scroll;
}
div::-webkit-scrollbar{
    width: 200px;
    background-color:#ddd;
}

拋開實用性,僅僅是模擬出這個樣式的話,這個方法真的讓人眼前一亮。

  

上述就是想到的 8 種方法,不排除有沒想到的,希望有其他的方法可以在評論中提出,具體 8 種實現可以戳這里看看:

codepen-單標簽左邊豎條的實現方式

 

所有題目匯總在我的 Github ,發到博客希望得到更多的交流。

到此本文結束,如果還有什么疑問或者建議,可以多多交流,原創文章,文筆有限,才疏學淺,文中若有不正之處,萬望告知。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM