CSS3中各種顏色屬性的使用教程

rgba 顏色
原本 CSS 中的顏色除了可用 16 進位來表示 RGB 顏色值之外,還可以使用預(yù)先定義好的顏色名稱。而 RGBA 是以 RGB 為基礎(chǔ)再加上不透明度的屬性。
- rgba(red, green, blue, opacity)
其中的 red、green 及 blue 等顏色值是用 10 進位或是百分比(%)的方式來表示,允許的值為 0 到 255 之間的整數(shù)值;而 opacity 不透明度允許的值為 0 到 1 之間帶有小數(shù)的數(shù)值。
快速的看一下實際的范例:
- <body>
- <div class="rgba1">rgba(0, 0, 0, 1)</div>
- <div class="rgba2">rgba(100%, 100%, 0%, 0.75)</div>
- <div class="rgba3">rgba(144, 180, 60, 1)</div>
- <div class="rgba4">rgba(204, 102, 102)</div>
- <div class="rgba5">rgba(300, -102, 0, 1)</div>
- <div id="log"></div>
- </body>
接著換 CSS:
- div {
- width: 220px;
- height: 50px;
- float: left;
- margin-right: 10px;
- line-height: 50px;
- text-align: center;
- border: 1px solid #000;
- }
基本用法:
- .rgba1 {
- /* 等同于 #ffffff 或是 rgba(100%, 100%, 100%, 1) */
- color: rgba(255, 255, 255, 1);
- /* 等同于 #000000 或是 rgba(0%, 0%, 0%, 1) */
- background-color: rgba(0, 0, 0, 1);
- }
- .rgba3 {
- background-color: rgba(144, 180, 60, 1);
- }
除了給實際的顏色值之外,也可以用百分比(%)來表示:
- .rgba2 {
- background-color: rgba(100%, 100%, 0%, 0.75);
- }
若是 opacity 值沒給的話,預(yù)設(shè)會用 0;這樣表示是透明(transparent)喔:
- .rgba4 {
- /* 沒有指定 opacity 值時, 預(yù)設(shè)使用 0 */
- background-color: rgba(204, 102, 102);
- }
如果顏色值超出限定的范圍時,則會用最接近的數(shù)值:
- .rgba5 {
- /* 超出范圍, 所以變成最接近的 rgba(255, 0, 0, 1) */
- background-color: rgba(300, -102, 0, 1);
- }
只要是顏色值的部份都能使用 rgab() 來設(shè)定。但當(dāng)要用程序來存取時,可能要注意一下各瀏覽器間的差異喔:
- $(function(){
- var str = '';
- $('div:not(#log)').each(function(){
- var $this = $(this);
- str += '.' + $this.attr('class') + ' : ' + $this.css('background-color') + '<br />';
- });
- $('#log').html(str);
- });
hsl 及 hsla 顏色
在 CSS3 中新增了 HSL 及 HSLA 等兩種跟顏色有關(guān)的屬性。其中 H 為 hue(色相)、S 為 saturation(飽合度)、L 為 lightness(亮度)。HSLA 就跟 RGBA 一樣,都是在原本的屬性中多加入了不透明度的設(shè)定而已。
- hsl(hue, saturation, lightness);
- hsla(hue, saturation, lightness, opacity);
hue 為整數(shù)的角度值,基本上是從 0 到 360 之間,因為它是經(jīng)過一個簡單的計算來處理所輸入的值:
- (((x mod 360) + 360) mod 360)
所以就算設(shè)定是 -10 的話,經(jīng)過計算后它也會變換成 350。而 0 或 360 表示紅色;60 表示黃色;120 表示綠色;240 表示藍色。
saturation 的表示方式為百分比(%);100% 就是最大飽合度,而 0% 則為灰色調(diào)。lightness 的表示方式也一樣是百分比(%);以 50% 為正常亮度為分界,百分比越高則會越接近白色(100%),而百分比越低則會越接近黑色(0%)。而 opacity 透明度允許的值為 0 到 1 之間帶有小數(shù)的數(shù)值。
一樣來看個簡單的范例:
- <body>
- <div class="hsl1">hsl(0, 50%, 50%)</div>
- <div class="hsl2">hsl(240, 80%, 50%)</div>
- <div class="hsl3">hsl(30, 100%, 50%)</div>
- <div class="hsla1">hsla(0, 100%, 0%, 0.8)</div>
- <div class="hsla2">hsla(210, 100%, 50%, 0.8)</div>
- <div id="log"></div>
- </body>
來看看 CSS 的用法:
- div {
- width: 220px;
- height: 50px;
- float: left;
- margin-right: 10px;
- line-height: 50px;
- text-align: center;
- border: 1px solid #000;
- }
- .hsl1 {
- color: hsl(0, 100%, 100%);
- background-color: hsl(0, 100%, 50%);
- }
- .hsl2 {
- color: hsl(0, 100%, 100%);
- background-color: hsl(240, 50%, 50%);
- }
- .hsl3 {
- background-color: hsl(30, 100%, 50%);
- }
- .hsla1 {
- color: hsl(0, 100%, 100%);
- background-color: hsla(0, 100%, 0%, 0.8);
- }
- .hsla2 {
- background-color: hsla(210, 100%, 50%, 0.8);
- }
基本上的用法就跟 rgb() 及 rgba() 一樣。但有趣的是,當(dāng)筆者嘗試使用 jQuery 取出顏色值時,原本用 hsl() 或 hsdl() 來設(shè)定的都會是轉(zhuǎn)換成 rgb() 及 rgba() 后的值。
- $(function(){
- var str = '';
- $('div:not(#log)').each(function(){
- var $this = $(this);
- str += '.' + $this.attr('class') + ' : ' + $this.css('background-color') + '<br />';
- });
- $('#log').html(str);
- });
相關(guān)文章
CSS實現(xiàn)大小相同、顏色深淺不一的粒子旋轉(zhuǎn)加載動畫
這篇文章主要介紹了CSS實現(xiàn)大小相同、顏色深淺不一的粒子旋轉(zhuǎn)加載動畫的相關(guān)代碼,運用CSS3的border-radius圓角屬性、box-shadow陰影屬性等屬性制作出來的,感興趣的小伙伴2016-04-25- 這篇文章主要介紹了CSS3中currentColor關(guān)鍵字的妙用,合理地使用currentColor往往會讓CSS代碼更加簡潔,同時也能與SVG圖標(biāo)很好地結(jié)合使用,需要的朋友可以參考下2016-02-27
- 這篇文章主要介紹了使用CSS3的::selection改變選中文本顏色的方法,也就是說可以將默認的藍色底色改為其他顏色,really cool,需要的朋友可以參考下2015-09-29
css實現(xiàn)兼容火狐、IE的LI奇偶行顏色交替方法
這篇文章主要為大家介紹了css實現(xiàn)兼容火狐、IE的LI奇偶行顏色交替方法,通過css屬性控制設(shè)置LI各行變色效果,具有一定參考借鑒價值,需要的朋友可以參考下2015-09-28- 這篇文章主要介紹了CSS中對RGB顏色的使用詳解,是CSS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-08-04
- 這篇文章主要介紹了CSS3中顏色線性漸變實戰(zhàn),示例中展示了代碼設(shè)置不同漸變方向的效果,需要的朋友可以參考下2015-07-18
使用CSS3的背景漸變Text Gradient 創(chuàng)建文字顏色漸變
使用CSS3 的背景漸變 -webkit-gradient ,用一個背景漸變的 DIV 代替圖片。下面是實現(xiàn)效果示例,相比以上方案優(yōu)點是不使用圖片,減小請求量和流量2014-08-19- 這是一款很漂亮的CSS3動畫進度條,可以用它來顯示每一項數(shù)據(jù)的所占的比例,效果很不錯2014-06-17
采用CSS3實現(xiàn)的表面顏色可漸變3D立方體動畫特效源碼
這是一款視覺效果超炫的采用CSS3實現(xiàn)的3D立方體動畫,與以往的立方體動畫效果不同的是,這款CSS3立方體動畫的幾個表面的背景顏色都有漸變的動畫效果,并且會伴隨著立方體的2014-06-17- 一款相對簡易的純CSS3 3D按鈕,可以自己配置背景顏色2014-06-11