也許你瞧不起之前的 css ,可是你不應再輕視眼下的 css 。近年來 css 的變量系統已逐步獲得各大瀏覽器廠商支持,自定義選擇器等強勢襲來,嵌套系統/模塊系統也在路上…爲了更好的掌握 css 這門語言,頗有必要把以前零零散散的 css 知識回爐重造下。javascript
css 做爲一門語言而,也有其繼承原理,雖然簡單,你卻未必掌握。css
屬性的是否默認繼承
初始值是指當屬性沒有指定值時的默認值,如這些語句的值都是默認值:background-color: transparent、left: auto 、float: none、width: auto 等。前端
css 的繼承很簡單,分爲默認繼承的和默認不繼承的,但全部屬性均可以經過設置 inherit 實現繼承。java
當沒有指定值時,默認繼承的屬性取父元素的同屬性的計算值(至關於設置了 inherit ),默認不繼承的屬性取屬性的初始值(時至關於設置了 initial )。web
默認繼承的 (「Inherited: Yes」) 的屬性:
全部元素默認繼承:visibility、cursor
內聯元素默認繼承:letter-spacing、word-spacing、white-space、line-height、color、font、 font-family、font-size、font-style、font-variant、font-weight、text- decoration、text-transform、direction
塊狀元素默認繼承:text-indent、text-align
列表元素默認繼承:list-style、list-style-type、list-style-position、list-style-image
表格元素默認繼承:border-collapse
默認不繼承的(「Inherited: No」) 的屬性:
文本屬性默認不繼承:vertical-align、text-decoration、text-shadow、white-space、unicode-bidi
盒子屬性默認不繼承:display、width、height、padding、margin、border、min-width、min-height、max-width、max-height、overflow、clip
背景屬性默認不繼承:background、background-color、background-image、background-repeat、background-position、background-attachment
定位屬性默認不繼承:float、clear、position、top、right、bottom、left、z-index
內容屬性默認不繼承:content、counter-reset、counter-increment
輪廓屬性默認不繼承:outline-style、outline-width、outline-color、outline
頁面屬性默認不繼承:size、page-break-before、page-break-after
聲音屬性默認不繼承:pause-before、pause-after、pause、cue-before、cue-after、cue、play-during
能夠看到涉及到文本相關的屬性,都是默認繼承的,畢竟 css 設計之初就是爲了更好的在網頁上呈現文字。瀏覽器
須要注意的是,部分屬性的默認值是會根據元素的 display 屬性的值而計算的,好比 vertical-align 屬性,若是是 display: inline 元素,則其計算值爲基線對齊 vertical-align: baseline ,若是是 display: inline-block 元素,則其計算值爲 vertical-align: bottom 。學習
通用屬性值 initial、inherit 和 unset
css 爲控制繼承提供了四個特殊的通用屬性值(屬性 revert 只有不多的瀏覽器支持,因此其實是三個),每一個 css 屬性都能使用這些值。spa
inherit
設置該屬性會使子元素屬性和父元素相同。實際上,就是「開啓繼承」。設計
initial
將屬性的初始值應用於元素。實際上,就是「重置爲默認值」。3d
unset
將屬性重置爲天然值,也就是若是屬性是天然繼承的那麼就是 inherit ,不然和 initial 同樣。
實例
這些通用屬性值能夠有不少妙用,舉個栗子:
利用 inherit 實現以下圖片倒影:
div::after { content: ""; position: absolute; top: 100%; left: 0; right: 0; bottom: -100%; background-image: inherit; // 背景圖片繼承,這通常人想不到吧... transform: rotateX(180deg); } 這是我建立的web前端開發學習q裙 851231348 分享學習的方法和須要注意的小細節,不停更新最新的教程和學習方法
initial
重置 left
爲默認值 auto
:div { position: absolute; left: 20px; top: 20px; } div + div { left: initial; right: 20px; }
例子中 div
設置過了 left
,div2 的 right
若要生效,須將 left
重置爲初始值 initial
(或者 unset
)。
unset
將屬性重置爲未設置以前的值:
例子中 p
標籤的 color
是默認繼承屬性,因此此時 color: unset
至關於 color: inherit
。 p
標籤的 border
屬性是默認不繼承屬性,因此此時 border: unset
至關於 border: initial
。
.unset { border: unset; color: unset; }
css 的繼承真的很簡單,只須要記住那些默認繼承的,剩下的都是默認不繼承的。而默認繼承的元素除了文本相關的哪些,只有 visibility、cursor
比較經常使用了,也是比較容易記得的。