CSS3中各种颜色属性的使用教程
2016-05-17 11:47
796 查看
rgba 颜色
原本 CSS 中的颜色除了可用 16 进位来表示 RGB 颜色值之外,还可以使用预先定义好的颜色名称。而 RGBA 是以 RGB 为基础再加上不透明度的属性。
其中的 red、green 及 blue 等颜色值是用 10 进位或是百分比(%)的方式来表示,允许的值为 0 到 255 之间的整数值;而 opacity 不透明度允许的值为 0 到 1 之间带有小数的数值。
快速的看一下实际的范例:
接着换 CSS:
基本用法:
除了给实际的颜色值之外,也可以用百分比(%)来表示:
若是 opacity 值没给的话,预设会用 0;这样表示是透明(transparent)喔:
如果颜色值超出限定的范围时,则会用最接近的数值:
只要是颜色值的部份都能使用 rgab() 来设定。但当要用程序来存取时,可能要注意一下各浏览器间的差异喔:
hsl 及 hsla 颜色
在 CSS3 中新增了 HSL 及 HSLA 等两种跟颜色有关的属性。其中 H 为 hue(色相)、S 为 saturation(饱合度)、L 为 lightness(亮度)。HSLA 就跟 RGBA 一样,都是在原本的属性中多加入了不透明度的设定而已。
hue 为整数的角度值,基本上是从 0 到 360 之间,因为它是经过一个简单的计算来处理所输入的值:
所以就算设定是 -10 的话,经过计算后它也会变换成 350。而 0 或 360 表示红色;60 表示黄色;120 表示绿色;240 表示蓝色。
saturation 的表示方式为百分比(%);100% 就是最大饱合度,而 0% 则为灰色调。lightness 的表示方式也一样是百分比(%);以 50% 为正常亮度为分界,百分比越高则会越接近白色(100%),而百分比越低则会越接近黑色(0%)。而 opacity 透明度允许的值为 0 到 1 之间带有小数的数值。
一样来看个简单的范例:
来看看 CSS 的用法:
基本上的用法就跟 rgb() 及 rgba() 一样。但有趣的是,当笔者尝试使用 jQuery 取出颜色值时,原本用 hsl() 或 hsdl() 来设定的都会是转换成 rgb() 及 rgba() 后的值。
原本 CSS 中的颜色除了可用 16 进位来表示 RGB 颜色值之外,还可以使用预先定义好的颜色名称。而 RGBA 是以 RGB 为基础再加上不透明度的属性。
rgba(red, green, blue, opacity)
其中的 red、green 及 blue 等颜色值是用 10 进位或是百分比(%)的方式来表示,允许的值为 0 到 255 之间的整数值;而 opacity 不透明度允许的值为 0 到 1 之间带有小数的数值。
快速的看一下实际的范例:
<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 值没给的话,预设会用 0;这样表示是透明(transparent)喔:
.rgba4 { /* 没有指定 opacity 值时, 预设使用 0 */ background-color: rgba(204, 102, 102); }
如果颜色值超出限定的范围时,则会用最接近的数值:
.rgba5 { /* 超出范围, 所以变成最接近的 rgba(255, 0, 0, 1) */ background-color: rgba(300, -102, 0, 1); }
只要是颜色值的部份都能使用 rgab() 来设定。但当要用程序来存取时,可能要注意一下各浏览器间的差异喔:
$(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 等两种跟颜色有关的属性。其中 H 为 hue(色相)、S 为 saturation(饱合度)、L 为 lightness(亮度)。HSLA 就跟 RGBA 一样,都是在原本的属性中多加入了不透明度的设定而已。
hsl(hue, saturation, lightness); hsla(hue, saturation, lightness, opacity);
hue 为整数的角度值,基本上是从 0 到 360 之间,因为它是经过一个简单的计算来处理所输入的值:
(((x mod 360) + 360) mod 360)
所以就算设定是 -10 的话,经过计算后它也会变换成 350。而 0 或 360 表示红色;60 表示黄色;120 表示绿色;240 表示蓝色。
saturation 的表示方式为百分比(%);100% 就是最大饱合度,而 0% 则为灰色调。lightness 的表示方式也一样是百分比(%);以 50% 为正常亮度为分界,百分比越高则会越接近白色(100%),而百分比越低则会越接近黑色(0%)。而 opacity 透明度允许的值为 0 到 1 之间带有小数的数值。
一样来看个简单的范例:
<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() 一样。但有趣的是,当笔者尝试使用 jQuery 取出颜色值时,原本用 hsl() 或 hsdl() 来设定的都会是转换成 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); });
相关文章推荐
- CSS3属性教程与案例分享
- CSS3属性教程与案例分享
- CSS3的calc()使用
- 使用CSS3的appearance属性改变元素的外观
- CSS3美化图片
- CSS3质感分析——表面线性渐变
- 分析选项卡底部内凹圆角制作
- 细说百度图片栏目——图片展示效果
- 8个实用的响应式设计框架
- 20+ Animation Scripts, Libraries and Plugins
- 新时代编辑神器:Atom
- 如何使用CSS3画出一个叮当猫
- 基于Jquery和CSS3制作数字时钟附源码下载(CSS3篇)
- C#及WPF获取本机所有字体和颜色的方法
- ScrollView滚动条颜色的设置方法
- jQuery CSS3相结合实现时钟插件
- C#实现HSL颜色值转换为RGB的方法
- 颜色快速采集器javascript代码
- CSS3实现动态翻牌效果 仿百度贴吧3D翻牌一次动画特效
- CSS3实例分享之多重背景的实现(Multiple backgrounds)