CSS3中各种颜色属性的如何使用好代码教程

初秋的风似一支七彩的画笔,走到哪里,哪里就披上秋的盛装,五光十色的鲜花和着七彩的蝴蝶,迎着丰收的景象。五彩缤纷的鲜花撒满大地,丰收的果园一派欣欣向荣的景象,金黄色的稻谷堆满仓,大地一片喜气洋洋。

rgba 颜色
原本 CSS 中的颜色除了可用 16 进位来表示 RGB 颜色值之外,还可以使用预先定义好的颜色名称。而 RGBA 是以 RGB 为基础再加上不透明度的属性。

CSS Code复制内容到剪贴板
  1. rgba(red,green,blue,opacity)

其中的 red、green 及 blue 等颜色值是用 10 进位或是百分比(%)的方式来表示,允许的值为 0 到 255 之间的整数值;而 opacity 不透明度允许的值为 0 到 1 之间带有小数的数值。

快速的看一下实际的范例:

XML/HTML Code复制内容到剪贴板
  1. <body>
  2. <divclass="rgba1">rgba(0,0,0,1)</div>
  3. <divclass="rgba2">rgba(100%,100%,0%,0.75)</div>
  4. <divclass="rgba3">rgba(144,180,60,1)</div>
  5. <divclass="rgba4">rgba(204,102,102)</div>
  6. <divclass="rgba5">rgba(300,-102,0,1)</div>
  7. <divid="log"></div>
  8. </body>

接着换 CSS:

CSS Code复制内容到剪贴板
  1. div{
  2. width:220px;
  3. height:50px;
  4. float:left;
  5. margin-right:10px;
  6. line-height:50px;
  7. text-align:center;
  8. border:1pxsolid#000;
  9. }

基本用法:

CSS Code复制内容到剪贴板
  1. .rgba1{
  2. /*等同于#ffffff或是rgba(100%,100%,100%,1)*/
  3. color:rgba(255,255,255,1);
  4. /*等同于#000000或是rgba(0%,0%,0%,1)*/
  5. background-color:rgba(0,0,0,1);
  6. }
  7. .rgba3{
  8. background-color:rgba(144,180,60,1);
  9. }

除了给实际的颜色值之外,也可以用百分比(%)来表示:

CSS Code复制内容到剪贴板
  1. .rgba2{
  2. background-color:rgba(100%,100%,0%,0.75);
  3. }

若是 opacity 值没给的话,预设会用 0;这样表示是透明(transparent)喔:

CSS Code复制内容到剪贴板
  1. .rgba4{
  2. /*没有指定opacity值时,预设使用0*/
  3. background-color:rgba(204,102,102);
  4. }

如果颜色值超出限定的范围时,则会用最接近的数值:

CSS Code复制内容到剪贴板
  1. .rgba5{
  2. /*超出范围,所以变成最接近的rgba(255,0,0,1)*/
  3. background-color:rgba(300,-102,0,1);
  4. }

只要是颜色值的部份都能使用 rgab() 来设定。但当要用程序来存取时,可能要注意一下各浏览器间的差异喔:

JavaScript Code复制内容到剪贴板
  1. $(function(){
  2. varstr='';
  3. $('div:not(#log)').each(function(){
  4. var$this=$(this);
  5. str+='.'+$this.attr('class')+':'+$this.css('background-color')+'<br/>';
  6. });
  7. $('#log').html(str);
  8. });

hsl 及 hsla 颜色
在 CSS3 中新增了 HSL 及 HSLA 等两种跟颜色有关的属性。其中 H 为 hue(色相)、S 为 saturation(饱合度)、L 为 lightness(亮度)。HSLA 就跟 RGBA 一样,都是在原本的属性中多加入了不透明度的设定而已。

CSS Code复制内容到剪贴板
  1. hsl(hue,saturation,lightness);
  2. hsla(hue,saturation,lightness,opacity);

hue 为整数的角度值,基本上是从 0 到 360 之间,因为它是经过一个简单的计算来处理所输入的值:

CSS Code复制内容到剪贴板
  1. (((xmod360)+360)mod360)

所以就算设定是 -10 的话,经过计算后它也会变换成 350。而 0 或 360 表示红色;60 表示黄色;120 表示绿色;240 表示蓝色。

saturation 的表示方式为百分比(%);100% 就是最大饱合度,而 0% 则为灰色调。lightness 的表示方式也一样是百分比(%);以 50% 为正常亮度为分界,百分比越高则会越接近白色(100%),而百分比越低则会越接近黑色(0%)。而 opacity 透明度允许的值为 0 到 1 之间带有小数的数值。

一样来看个简单的范例:

XML/HTML Code复制内容到剪贴板
  1. <body>
  2. <divclass="hsl1">hsl(0,50%,50%)</div>
  3. <divclass="hsl2">hsl(240,80%,50%)</div>
  4. <divclass="hsl3">hsl(30,100%,50%)</div>
  5. <divclass="hsla1">hsla(0,100%,0%,0.8)</div>
  6. <divclass="hsla2">hsla(210,100%,50%,0.8)</div>
  7. <divid="log"></div>
  8. </body>

来看看 CSS 的用法:

CSS Code复制内容到剪贴板
  1. div{
  2. width:220px;
  3. height:50px;
  4. float:left;
  5. margin-right:10px;
  6. line-height:50px;
  7. text-align:center;
  8. border:1pxsolid#000;
  9. }
  10. .hsl1{
  11. color:hsl(0,100%,100%);
  12. background-color:hsl(0,100%,50%);
  13. }
  14. .hsl2{
  15. color:hsl(0,100%,100%);
  16. background-color:hsl(240,50%,50%);
  17. }
  18. .hsl3{
  19. background-color:hsl(30,100%,50%);
  20. }
  21. .hsla1{
  22. color:hsl(0,100%,100%);
  23. background-color:hsla(0,100%,0%,0.8);
  24. }
  25. .hsla2{
  26. background-color:hsla(210,100%,50%,0.8);
  27. }

基本上的用法就跟 rgb() 及 rgba() 一样。但有趣的是,当笔者尝试使用 jQuery 取出颜色值时,原本用 hsl() 或 hsdl() 来设定的都会是转换成 rgb() 及 rgba() 后的值。

JavaScript Code复制内容到剪贴板
  1. $(function(){
  2. varstr='';
  3. $('div:not(#log)').each(function(){
  4. var$this=$(this);
  5. str+='.'+$this.attr('class')+':'+$this.css('background-color')+'<br/>';
  6. });
  7. $('#log').html(str);
  8. });

以上就是CSS3中各种颜色属性的如何使用好代码教程。这个世界上有很多失败的人,他们失败的主要原因就是不懂得如何做出选择,他们不明白什么才能够让自己的能力的到施展。所以成功的人,总是选择最好的条件和环境发挥自己的潜能,获得最后的成功。更多关于CSS3中各种颜色属性的如何使用好代码教程请关注haodaima.com其它相关文章!

您可能有感兴趣的文章
css让页脚保持在底部位置的四种方案

CSS如何使用Flex和Grid布局如何实现3D骰子

Flex布局史上最简单使用语法教程

新的CSS 伪类函数 :is() 和 :where()示例详解

纯CSS打字动画的如何实现示例