讓css的權重變得更友好的小技巧

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

技巧一:樣式總是作為特定屬性群組合出現

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

技巧二:使用動態值,比如currentColor和em等

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

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

技巧三:使用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屬性自動匹配顏色。或許你不需要改變什麼,可以將一個亮色系變成一個暗色系。

技巧四:每當你寫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的代碼處理健康狀態。

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

相關文章

Alibaba Cloud 10 Year Anniversary

With You, We are Shaping a Digital World, 2009-2019

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。