css中你不知道的小技巧

來源:互聯網
上載者:User
CSS中的級聯(cascade)在同一時間可謂是幸福的,也可以說是痛苦不堪的。通常能工作得非常好,但有問題的時候,也讓人們都很激動,甚至事件中也離開不CSS。我們所涉及的不僅是CSS的級聯也還涉及到CSS的權重。不是說碰到特殊問題才顯得困難,可以說CSS的困難無處不在。

在這篇文章中,我將通過一些樣本來向大家展示一些CSS的小技巧,讓你知道如何使用CSS的級聯能變得更友好,也減少一些不必要的需求,從而也減少權重上遇到的麻煩。

技巧一

每當你寫CSS時,你想儘可能的回到樹形頂部。換句話說,回到:root。

例如,我們的網站有一個側邊欄,希望在這個側邊欄上添加一個簡短的個人介紹。其HTML的結構看起來可能會像這樣:

<body>    <main class=“Posts”>    <aside class=“SideBar”>        <nav class=“Nav”>        <p class=“Bio”>

CSS是這樣寫的:

.Bio {    font-size: .8em;    line-height: 1.5;    color: #888;}

這樣寫是能正常工作的,並不存在樣式上的問題。但是,側邊欄還有一個導航nav,很有可能他們有一些樣式是相同的。在我們這個樣本中font-size和color都是相同的。讓我們把這些屬性從nav和.Bio中提取出來,並且將它們添加到其父元素.SideBar中:

.SideBar {    font-size: .8em;    color: #888;}

事實證明,在.Posts中已經設定了line-height:1.5;。似乎整個頁面都使用了相同的行高,那麼我們可以將.Bio和.Posts中的line-height移到根項目中:

:root {    line-height: 1.5;}

這看起來是一個CSS常識,但他也不會太關注兄弟元素定義同樣的事情。這也讓你發現,有一些代碼產生重複。其實這並不可怕,因為我們只需要花點時間重新重構代碼,但這樣保持了CSS的代碼處理健康狀態。

在樹支上寫樣式,而不應該在樹葉上寫樣式

技巧二

樣式總是作為特定屬性群組合出現

一個很好的例子就是color和bakground-color的組合。除非你只做小調整,不然你需要一起調整他們。當給一個元素添加背景顏色時,它可能不包含任何文本,但可能會有一些子項目。因此,我們一起設定前景色彩(color)和背景色(background-color),我們總是可以確定這些元素不會遇到任何易讀性和對比問題。下次我們改變背景色時,不需要到處尋找需要修改的文本顏色,因為他們都以一個組合的形式出現在一起。

技巧三

使用動態值,比如currentColor和em等

有時候文本顏色也會使用在其他屬性上。比如說border、box-shadow或者SVG表徵圖中的fill上。定義相同顏色有一個替代方案,可以直接使用currentColor。預設情況下,color是可以繼承的,你只需要在一個地方修改就可以改變其他屬性的顏色。

同樣的,給font-size屬性使用em單位,允許你只修改:root的font-size就可以改變元素的盒模型大小。

有關於這方面更多的細節,可以查閱《使用字串(STRINGS)設定樣式》一文。

技巧四

使用inherit屬性值繼承其父元素樣式來覆蓋UA內建樣式。

像button、input這樣的表單控制項,不同的瀏覽器都會有自己的樣式風格(UA樣式)。我們可以使用inherit繼承其父元素樣式,從而覆蓋瀏覽器的UA樣式。

button,input,select,textarea {    color: inherit;    font-family: inherit;    font-style: inherit;    font-weight: inherit;}

上面範例程式碼取自sanitize.css。normalize.css也是這樣使用的。如果你不是這樣使用,說明你已經...

你也可以嘗試在input[type="range"]、input[type="radio"]和input[type="checkbox"]等元素上直接使用前面介紹的currentColor屬性自動匹配顏色。或許你不需要改變什麼,可以將一個亮色系變成一個暗色系。

總結

這些都是好東西,當然並不是強迫大家使用。我想說,這些小技巧,簡單實用,讓你的Web網站能擷取最大的好處。即使你使用一個CSS前置處理器,他們也不會有損代碼的輸出量減少,甚至可以少設定幾個變數。

也適合單一類名,比如像Tachyons。或許還能減少複雜性和所需的類。

另外一個有趣的事情即將到來,那麼在CSS中也可以自訂屬性,也就是CSS變數。與前置處理器不同,覆蓋自訂屬性時,它只會影響當前的選擇範圍。所以從某種意義上來說,他們是“層疊變數”。

  • 相關文章

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.