自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

CSS 中 Rgb 與 Rgba 的進化史

開發(fā) 前端
我最早工作是需要兼容 IE6 的,所以對這塊還算熟悉。在這個時代,只有Rgb,沒有Rgba,也就是這種最原始的寫法,因此如果要實現(xiàn)透明度顏色,要么整體透明,要么切圖,是一件非常頭疼的事。

提到顏色,大家都能想到 rgb 顏色表示法,比如 rgb(255,0,0)就表示紅色,如果希望有透明度,可以用rgba來表示,比如rgba(255,0,0,.5)就表示透明度為50%的紅色。

除了這些,你還知道哪些?還有哪些新的寫法,兼容性如何?今天一起來聊聊 rgb 和 rgba 的發(fā)展史。

一、IE8 之前(2012前)

我最早工作是需要兼容 IE6 的,所以對這塊還算熟悉。

在這個時代,只有rgb,沒有rgba,也就是這種最原始的寫法。

rgb(255,0,0)

因此如果要實現(xiàn)透明度顏色,要么整體透明,要么切圖,是一件非常頭疼的事。

兼容性如下,全兼容。

二、IE9 ~ Safari 12(2019前)

為了解決透明度的問題,從 IE9 開始支持rgba顏色表示法,這里的a就是alpha,也就是透明的意思。

rgba(255,0,0,.5)

這個階段應(yīng)該是目前絕大多數(shù)前端開發(fā)都經(jīng)歷的時期,由于這段時期,JS框架發(fā)展迅猛,導(dǎo)致很多同學(xué)誤以為CSS 顏色就到此為止了,反正平時的開發(fā)也夠用。

需要注意的是,rgba這里的透明度是必須的,即使是1也要寫上。

/*舊瀏覽器不支持*/
rgba(255,0,0) 
/*正確的寫法*/
rgba(255,0,0,1)

還有為啥是 Safari 12呢?因為從Safari 12.1開始支持新的rgb顏色,并且是主流瀏覽器中支持最晚的。

兼容性如下,IE9 以上全兼容。

三、Safari 12.1 ~ 至今(2019以后)

接下來就是 CSS Color Level 4 的更新,顏色表示變得極其自由,非常離譜,也是大多數(shù)同學(xué)沒有注意到的一次變革。

最大的特征是去除了逗號,改用空格作為分隔符,還支持透明度可選,如果有透明度,就用斜杠/來區(qū)分。

rgb(255 0 0)
rgb(255 0 0 / .5)

由于 CSS極其強大的向后兼容性,因此也保留了以前逗號的寫法。

rgb(255,0,0)
rgb(255,0,0,.5)

另外,還有一點比較隱晦,就是透明度alpha還支持了百分比格式,注意是「透明度」,其他值舊語法就支持。

rgb(255 0 0 / 50%)
rgb(100% 0% 0% / 50%)

注意,這里的0必須也寫成0%,也就是r、g、b的形式必須統(tǒng)一,要么都是數(shù)值,要么都是百分比,但是和透明度可以不一致,例如:

/*以下合法*/
rgb(100% 0% 0% / .5)
rgb(255 0 0 / 50%)

更夸張的是,當用百分比表示時,空格也是可以省略的(當然并不推薦)。

rgb(100%0%0%/50%)

還支持一個關(guān)鍵詞none,也就是0,幾乎沒啥用。

rgb(255 0 0 / none)

有人可能覺得奇怪,既然rgb也支持透明度了,那rgba干嘛去了?

沒錯,現(xiàn)在 rgba() 語法相當于是 rgb() 的別稱,完全是一模一樣的,寫不寫a都一樣。

rgba(255 255 255)
rgba(255 255 255 / .5)
rgba(255,0,0)
rgba(255,0,0,.5)
rgba(100% 0% 0%)
rgba(100% 0% 0% / 50%)
rgba(100% 0% 0% / .5)
rgba(255 0 0 / 50%)

兼容性如下,主要是 safari 12.1還有點不放心。

怎么樣,是不是都記住了?下面來看兩道選擇題

四、簡單測試一下

第一題,請問下面哪些顏色是合法的?

A. rgb(255, 0, 0, 2)
B. rgb(255, 0, 0, -1)
C. rgb(300, 0, 0, 1)
D. rgb(100%, 0, 0, 1)
E. rgb(255, 0, 0 / 100%)
F. rgba(100%0%0%)
G. rgba(255 0 0 1)

思考幾分鐘...

答案揭曉:合法的是A、B、C、F。

答案解析:

首先關(guān)于閾值,顏色處理非常靈活,比如透明度超過1就解析成1,小于0就解析成0,所以 A、B、C都是合法的。

其次,百分比和數(shù)值不能混用,所以D不合法。

然后逗號和/不能混用,所以E不合法。

接著,用百分比表示時可以省略空格,所以F合法。

最后,用空格分隔時,透明度需要用/區(qū)分,所以G不合法。


第二題,請問下面哪些顏色是CSS color 4新語法?(safari 12.1+支持)。

A. rgba(255, 0, 0,50%)
B. rgba(100%, 0%, 0%, 50%)
C. rgba(100%, 0%, 0%, .5)
D. rgba(255, 0, 0)
E. rgb(255 0 0)
F. rgb(300, 0, 0, 1)
G. rgb(100%, 0%, 0%)

思考幾分鐘...

答案揭曉:屬于新語法的是A、B、D、E、F。

答案解析:

首先來看 rgba,只要透明度是百分比格式的,都是新語法,所以 A、B符合。

然后在舊語法中,rgba 中的透明度是必須的,可以省略的就是新語法,所以 D 也是新語法。

接著,新語法才支持空格作為分隔符,所以 E 也是新語法。

rgb 支持透明度也是新語法,所以 F 也符合。

其他就都是舊語法了。

怎么樣,你答對了嗎?

五、實際開發(fā)需要注意的

實際開發(fā)中,我相信絕大部分同學(xué)都會穩(wěn)妥起見(可能是不知道有新語法),使用舊語法。

rgb(255,0,0)
rgba(255,0,0,0)

大部分設(shè)計軟件展示的也是這類舊語法,比如下面的 Figma。

正常情況下本來沒什么事,用這些舊語法也滿足需求。但有時候,一些 eslint 在不配置的情況下可能會自作主張的給你轉(zhuǎn)換了(在 git 提交的時候轉(zhuǎn)換),比如明明寫的是 rgba 語法,結(jié)果被轉(zhuǎn)成了 rgb。

rgba(255,0,0,0.5)
/*eslint轉(zhuǎn)換后*/
rgb(255 0 0 /50%)

這個還好,比較容易發(fā)現(xiàn),還有一種就比較隱晦了,比如下面這種。

rgba(255,0,0,0.5)
/*eslint轉(zhuǎn)換后*/
rgba(255,0,0,50%)

僅僅是把透明度做了轉(zhuǎn)換,這是個新語法,但是很難被發(fā)現(xiàn),結(jié)果就有可能在低版本 ios (safari 12以下)出現(xiàn)顏色丟失。

當然這些 eslint 都是可以配置的,比如上面的這些問題可以用這樣的配置來解決。

"color-function-notation": 'legacy',
"alpha-value-notation": 'number'

但是,對于不熟悉這些配置的(比如我)簡直就是災(zāi)難!??

六、最后總結(jié)一下

以上就是本文的全部內(nèi)容了,相信大家對 rgb 顏色的發(fā)展以及兼容性有了一定的印象,下面總結(jié)一下

  • IE8之前只支持rgb顏色。
  • IE9到 safari 12 期間支持了rgba顏色,注意此時的a是必須的。
  • safari 12.1以上迎來了 CSS color 4顏色大變革,寫法極其自由。
  • 最大的特征是去除了逗號,改用空格作為分隔符,還支持透明度可選。
  • 為了向下兼容,也支持傳統(tǒng)逗號分隔。
  • 透明度支持百分比,這個變化比較微妙,很容易被忽視。
  • 其他細節(jié)可以查看以上兩道選擇題。
  • 很多問題可能是工程化工具自動修改的,可能需要一定的配置來解決。

可能你根本不會去使用這些新語法,但是如果你在項目中碰到一些顏色丟失的問題,可以朝這個方向來排查。

責任編輯:姜華 來源: 前端偵探
相關(guān)推薦

2011-12-21 16:44:00

信息圖手機進化史

2014-09-01 16:29:34

2010-07-27 14:04:52

2011-11-03 15:25:07

Android

2011-11-29 09:54:20

Google進化史

2011-09-01 09:34:21

架構(gòu)

2018-03-23 12:20:25

數(shù)據(jù)中心網(wǎng)絡(luò)數(shù)據(jù)

2010-10-09 14:46:20

2024-09-21 10:43:15

數(shù)據(jù)技術(shù)信息

2019-11-26 10:04:50

開源云計算Hadoop

2013-06-24 09:18:05

2010-04-07 14:54:20

Unix操作系統(tǒng)

2022-03-25 14:01:20

元宇宙虛擬世界進化

2016-02-04 09:17:59

2010-01-21 16:08:26

C++語言

2018-08-22 17:58:01

數(shù)據(jù)平臺數(shù)據(jù)倉庫架構(gòu)

2022-03-29 09:35:15

FirefoxUI瀏覽器

2014-08-13 10:31:26

Windows操作系統(tǒng)

2019-06-19 15:54:12

Redis緩存內(nèi)存

2011-11-04 15:58:52

手機操作系統(tǒng)進化史
點贊
收藏

51CTO技術(shù)棧公眾號