摘要:中的繼承實(shí)際上是父級(jí)元素對(duì)子元素的影響。如果使用的屬性為繼承屬性,則將其視為,否則則視為。張載名言警句人若志趣不遠(yuǎn),心不在焉,雖學(xué)不成。張載效果如下代碼在我中,大家可以隨時(shí)查看。
繼承作者:陳大魚(yú)頭
github: KRISACHAN
繼承(英語(yǔ):inheritance) 是面向?qū)ο筌浖夹g(shù)當(dāng)中的一個(gè)概念。在 CSS 中與 層疊(英語(yǔ):Cascade) 一起描述了如何設(shè)置樣式規(guī)則,并為所有元素的所有屬性賦值。這兩個(gè)屬性同屬規(guī)范 “ CSS Cascading and Inheritance Level ”。CSS中的 繼承 實(shí)際上是父級(jí)元素對(duì)子元素的影響。
在之前的文章中,我們介紹過(guò) 層疊(優(yōu)先級(jí)) 的規(guī)則,這里我們先復(fù)習(xí)一下:
選擇器 | 千位 | 百位 | 十位 | 個(gè)位 | 合計(jì)值 |
---|---|---|---|---|---|
h1 | 0 | 0 | 0 | 1 | 0001 |
#indentifier | 0 | 1 | 0 | 0 | 0100 |
h1 + p::first-letter | 0 | 0 | 0 | 3 | 0003 |
li > a[href*="zh-CN"] > .inline-warning | 0 | 0 | 2 | 2 | 0022 |
沒(méi)有選擇器, 規(guī)則在一個(gè)元素的 屬性里 | 1 | 0 | 0 | 0 | 1000 |
魚(yú)頭注:有很多人會(huì)認(rèn)為 !important 也參與了優(yōu)先級(jí)的排列,但 !important 是在優(yōu)先級(jí)的規(guī)則之外的,如果參與了優(yōu)先級(jí)的排列,意思就是 !important 是可以被覆蓋的,但事實(shí)顯然不是。
接下來(lái)我們談?wù)?CSS中的繼承。
特殊的通用屬性值CSS為處理繼承提供了四種特殊的通用屬性值,其值如下:
值 | 意義 |
---|---|
inherit | 屬性初始值。 |
initial | 繼承的值。 |
unset | 如果使用 unset 的屬性為繼承屬性,則將其視為 inerit,否則則視為 initial。 |
revert | 屬性值被設(shè)置成自定義樣式所定義的屬性(如果被設(shè)置), 否則屬性值被設(shè)置成用戶代理的默認(rèn)樣式。 |
在這里分享一個(gè)CSS屬性all。CSS all 簡(jiǎn)寫(xiě)屬性 將除卻 unicode-bidi 與 direction 之外的所有屬性重設(shè)至其初始值,或繼承值。 all 的值可以如下:
/* Global values */ all: initial all: inherit all: unset /* CSS Cascading and Inheritance Level 4 */ all: revert;
以上四值的功能如上面的表一樣。這里我們重點(diǎn)分享一下 revert。revert關(guān)鍵字指定依賴于CSS聲明的源:
用戶代理源(user-agent origin):瀏覽器會(huì)有一個(gè) 基本的樣式表 來(lái)給任何網(wǎng)頁(yè)設(shè)置默認(rèn)樣式,這些樣式統(tǒng)稱用戶代理樣式,等同于 unset。
用戶源(user origin):網(wǎng)站的用戶(或讀者)所選擇的自定義樣式,主要是根據(jù)用戶的一員定制(例如用戶自定義的系統(tǒng)主題與字體)。
作者源(author origin):網(wǎng)站開(kāi)發(fā)者定義的樣式。
例子如下:
雞湯大全
名言警句
人若志趣不遠(yuǎn),心不在焉,雖學(xué)不成。 — 張載名言警句(all: unset)
人若志趣不遠(yuǎn),心不在焉,雖學(xué)不成。 — 張載名言警句(all: initial)
人若志趣不遠(yuǎn),心不在焉,雖學(xué)不成。 — 張載名言警句(all: inherit)
人若志趣不遠(yuǎn),心不在焉,雖學(xué)不成。 — 張載
效果如下:
代碼在我codepen (https://codepen.io/krischan77... 中,大家可以隨時(shí)查看。
魚(yú)頭注:至于CSS中可繼承的屬性有點(diǎn)多,我就不列出來(lái)了,各位有興趣的可以看看這個(gè)問(wèn)題:https://stackoverflow.com/questions/5612302/which-css-properties-are-inherited 。
計(jì)算值(Computed Value)計(jì)算值(Computed Value) 是解析指定屬性值的結(jié)果,通過(guò)將其絕對(duì)化用以繼承。
計(jì)算值(Computed Value) 用以繼承時(shí)是由父節(jié)點(diǎn)傳達(dá)到子節(jié)點(diǎn)的值,由于歷史原因,它不一定是由 getComputedStyle() 返回的結(jié)果。
常見(jiàn)的計(jì)算值(Computed Value) 有:em、ex、vh、vw、smaller、bolder等不固定具體px尺寸的值。
下面是一個(gè)不同計(jì)算值單位下盒子的寬度變化的DEMO
代碼有點(diǎn)長(zhǎng),就不貼出來(lái)了,有興趣可以點(diǎn)開(kāi)鏈接嘗試一下:https://krissarea.gitee.io/bl...。
功能表示法(Functional Notations)功能表示法是一種組件值,可以表示更復(fù)雜的類型或調(diào)用特殊處理。主要分有以下三個(gè)部分:
數(shù)學(xué)表達(dá)式(用以四則運(yùn)算):calc()、 min()、max()和clamp()。
切換值(允許子元素循環(huán)調(diào)用傳入?yún)?shù)):toggle()。
屬性引用(獲取引用的屬性):attr()。
以上功能屬性,在之前的章節(jié)中也提到過(guò),目前能用的就只有 calc() 跟 attr(),但是即便如此,這兩個(gè)函數(shù)已經(jīng)卻也已經(jīng)發(fā)揮出了很強(qiáng)大的功能。
var()var() 是 CSS Custom Properties for Cascading Variables Module Level 1 的內(nèi)容,中文名叫 自定義屬性,并不叫CSS變量,并不叫CSS變量,并不叫CSS變量,重要的內(nèi)容說(shuō)三次。
語(yǔ)法如下:
var(, ? )
方法的第一個(gè)參數(shù)是要替換的自定義屬性的名稱。函數(shù)的可選第二個(gè)參數(shù)用作回退值。如果第一個(gè)參數(shù)引用的自定義屬性無(wú)效,則該函數(shù)將使用第二個(gè)值。
我們可以在任何選擇器中聲明,例子如下:
// 下面的定義都是有效的 :root { --color: red; } @media (min-width: 300px) { :root { --color: blue; } } .color { --color: white; } a { color: var(--color, black); }
從上面的代碼我們可以知道,自定義屬性不僅僅可以在全局作用域下定義,甚至也可以在局部作用域下定義,這點(diǎn)是一些 CSS處理器 所無(wú)法實(shí)現(xiàn)的。
我們知道,CSS目前還沒(méi)有條件判斷的功能,但是我們藉由數(shù)學(xué)表達(dá)式函數(shù) calc() 也可以實(shí)現(xiàn)很多有趣的功能。
這里我們分享一個(gè)由 var() 跟 calc() 實(shí)現(xiàn)的進(jìn)度條功能,效果如下:
代碼在我codepen: https://codepen.io/krischan77/pen/QPezjB中,各位隨時(shí)可以去看效果。
currentColor關(guān)鍵字 currentColor 是屬性 color 的值,如果 color 上設(shè)置 currentColor ,則將其視為 color: inherit。
border 和 box-shadow 默認(rèn)的顏色就是當(dāng)前的文字顏色,也就是類似 currentColor。
嗯,所以有什么用?
我們可以通過(guò) currentColor 來(lái)輕松實(shí)現(xiàn)換膚功能。DEMO如下:
你想換的顏色:
currentColor 是 CSS3 中非常好用的一個(gè)關(guān)鍵字,利用它我們就可以輕松實(shí)現(xiàn)文本顏色與圖形之間的互動(dòng)。
說(shuō)到這里,不知道大家有沒(méi)有覺(jué)得很奇怪, 像 multi-word 這種具有連字符的單詞才是 CSS 中的常規(guī)命名,而 currentColor 確是駝峰命名?如果你知道答案的話,可以在下方留言區(qū)域留言回答,不知道的話也沒(méi)關(guān)系,可以持續(xù)關(guān)注魚(yú)頭的 『Hello CSS』,魚(yú)頭會(huì)在下一篇文章中解答。
后記本文主要簡(jiǎn)單分享了 CSS 的繼承與可變性,同時(shí)也再次地回顧了之前系列中所分享過(guò)的層級(jí),函數(shù)等內(nèi)容,一方面是想做個(gè)整理歸納,如果 CSS 屬性分配得恰當(dāng),不僅可以減輕我們很多的工作量,也可以輕松實(shí)現(xiàn)一些比較有趣的效果,更重要是可以減少JS 與 CSS 的耦合度,對(duì)我們的開(kāi)發(fā)與后期維護(hù)也是有很大幫助的。
大家也不妨多挖掘挖掘 CSS 的潛在能力,這也許會(huì)帶來(lái)意想不到的收獲。
參考資料:CSS Cascading and Inheritance Level 4
CSS Values and Units Module Level 4
Origin of CSS declarations
【Hello CSS】系列【Hello CSS】是以CSS基礎(chǔ)概念為主題的系列文章,旨在幫助大家更深刻地了解并且提高CSS在各位開(kāi)發(fā)者心目中的地位。由于魚(yú)頭我水平有限,文筆有限,如果各位在文章中發(fā)現(xiàn)有任何不合理,不正確的地方,還煩不吝指出,我會(huì)非常感謝的;如果通過(guò)文章有任何想法或疑問(wèn),也希望各位能積極留言,我們互相探討;如果通過(guò)本系列文章有所收獲,這就讓魚(yú)頭我喜不自勝了!
如果你也喜歡 CSS,喜歡探討技術(shù),或者對(duì)本文,本系列有任何的意見(jiàn)或建議,你可以掃描下方二維碼,關(guān)注微信公眾號(hào)“ 魚(yú)頭的Web海洋 ”,隨時(shí)與魚(yú)頭互動(dòng)。歡迎!衷心希望可以遇見(jiàn)你。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/115005.html
摘要:中的繼承實(shí)際上是父級(jí)元素對(duì)子元素的影響。特殊的通用屬性值為處理繼承提供了四種特殊的通用屬性值,其值如下值意義繼承的值。如果使用的屬性為繼承屬性,則將其視為,否則則視為。 作者:陳大魚(yú)頭 github: KRISACHAN 繼承 繼承(英語(yǔ):inheritance) 是面向?qū)ο筌浖夹g(shù)當(dāng)中的一個(gè)概念。在 CSS 中與 層疊(英語(yǔ):Cascade) 一起描述了如何設(shè)置樣式規(guī)則,并為所有...
摘要:原文發(fā)表于以太坊智能合約開(kāi)發(fā)第七篇智能合約與網(wǎng)頁(yè)交互上一篇中,我們通過(guò)開(kāi)發(fā)框架快速編譯部署了合約。智能合約與網(wǎng)頁(yè)交互啟動(dòng)腳本修改完了之后,就需要與網(wǎng)頁(yè)進(jìn)行整合。 原文發(fā)表于:以太坊智能合約開(kāi)發(fā)第七篇:智能合約與網(wǎng)頁(yè)交互 上一篇中,我們通過(guò)truffle開(kāi)發(fā)框架快速編譯部署了合約。本篇,我們將來(lái)介紹網(wǎng)頁(yè)如何與智能合約進(jìn)行交互。 編寫(xiě)網(wǎng)頁(yè) 首先我們需要編寫(xiě)一個(gè)網(wǎng)頁(yè)。打開(kāi) smartcon...
摘要:精確控制表格列寬請(qǐng)注意,為了確保這個(gè)技巧奏效,需要為這些表格元素指定一個(gè)寬度哪怕是。同樣,為了讓發(fā)揮作用,我們還需要為那一列指定寬度。 自適應(yīng)內(nèi)部元素 figure{ max-width: 300px; max-width: min-content;//這個(gè)關(guān)鍵字將解析為這個(gè)容器內(nèi)部最大的不可斷行元素的寬度( 即最寬的單詞、 圖片或具有固定寬度的盒元素。 mar...
摘要:函數(shù)內(nèi)置不可變,在函數(shù)體內(nèi)整個(gè)執(zhí)行環(huán)境中為常量。這兩個(gè)方法的用途都是在特定的作用域中調(diào)用函數(shù),實(shí)際上等于設(shè)置函數(shù)體內(nèi)的對(duì)象的值。控制表單控件的禁用狀態(tài)。生成相對(duì)定位的元素,相對(duì)于其在普通流中的位置進(jìn)行定位。 Javasript 1.請(qǐng)定義一個(gè)方法,傳入一個(gè)string類型的參數(shù),然后將string的每個(gè)字符間加個(gè)空格返回 spacify(hello world) // => h e l...
摘要:函數(shù)內(nèi)置不可變,在函數(shù)體內(nèi)整個(gè)執(zhí)行環(huán)境中為常量。這兩個(gè)方法的用途都是在特定的作用域中調(diào)用函數(shù),實(shí)際上等于設(shè)置函數(shù)體內(nèi)的對(duì)象的值。控制表單控件的禁用狀態(tài)。生成相對(duì)定位的元素,相對(duì)于其在普通流中的位置進(jìn)行定位。 Javasript 1.請(qǐng)定義一個(gè)方法,傳入一個(gè)string類型的參數(shù),然后將string的每個(gè)字符間加個(gè)空格返回 spacify(hello world) // => h e l...
閱讀 2073·2021-10-11 10:59
閱讀 932·2021-09-23 11:21
閱讀 3559·2021-09-06 15:02
閱讀 1619·2021-08-19 10:25
閱讀 3374·2021-07-30 11:59
閱讀 2370·2019-08-30 11:27
閱讀 2583·2019-08-30 11:20
閱讀 2976·2019-08-29 13:15