css实战手册第四版 pdf_你真的了解CSS继承吗?看完必跪
也許你瞧不起以前的 css ,但是你不該再輕視眼下的 css 。近年來 css 的變量系統(tǒng)已逐步得到各大瀏覽器廠商支持,自定義選擇器等強勢襲來,嵌套系統(tǒng)/模塊系統(tǒng)也在路上...為了更好的掌握 css 這門語言,很有必要把之前零零散散的 css 知識回爐重造下。
css 作為一門語言而,也有其繼承原理,雖然簡單,你卻未必掌握。
屬性的是否默認繼承
初始值是指當屬性沒有指定值時的默認值,如這些語句的值都是默認值:background-color: transparent、left: auto 、float: none、width: auto 等。
css 的繼承很簡單,分為默認繼承的和默認不繼承的,但所有屬性都可以通過設置 inherit 實現(xiàn)繼承。
當沒有指定值時,默認繼承的屬性取父元素的同屬性的計算值(相當于設置了 inherit ),默認不繼承的屬性取屬性的初始值(時相當于設置了 initial )。
默認繼承的 ("Inherited: Yes") 的屬性:
- 所有元素默認繼承:visibility、cursor
- 內聯(lián)元素默認繼承: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 設計之初就是為了更好的在網頁上呈現(xiàn)文字。
需要注意的是,部分屬性的默認值是會根據(jù)元素的 display 屬性的值而計算的,比如 vertical-align 屬性,如果是 display: inline 元素,則其計算值為基線對齊 vertical-align: baseline ,如果是 display: inline-block 元素,則其計算值為 vertical-align: bottom 。
通用屬性值 initial、inherit 和 unset
css 為控制繼承提供了四個特殊的通用屬性值(屬性 revert 只有很少的瀏覽器支持,所以實際上是三個),每個 css 屬性都能使用這些值。
- inherit
設置該屬性會使子元素屬性和父元素相同。實際上,就是“開啟繼承”。
- initial
將屬性的初始值應用于元素。實際上,就是“重置為默認值”。
- unset
將屬性重置為自然值,也就是如果屬性是自然繼承的那么就是 inherit ,否則和 initial 一樣。
實例
這些通用屬性值可以有很多妙用,舉個栗子:
例子中 div 設置過了 left ,div2 的 right 若要生效,須將 left 重置為初始值 initial (或者 unset)。
例子中 p 標簽的 color 是默認繼承屬性,所以此時 color: unset 相當于 color: inherit 。 p 標簽的 border 屬性是默認不繼承屬性,所以此時 border: unset 相當于 border: initial 。
.unset { border: unset; color: unset;}web前端開發(fā)學習Q-q-u-n: 784783012 ,分享學習的方法和需要注意的小細節(jié),不停更新最新的教程和學習方法(詳細的前端項目實戰(zhàn)教學視頻,PDF)總結
css 的繼承真的很簡單,只需要記住那些默認繼承的,剩下的都是默認不繼承的。而默認繼承的元素除了文本相關的哪些,只有 visibility、cursor 比較常用了,也是比較容易記得的。
總結
以上是生活随笔為你收集整理的css实战手册第四版 pdf_你真的了解CSS继承吗?看完必跪的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: css 字体加粗_HTML基础属性与CS
- 下一篇: python链接mysql报错2003_