熟悉css/css3颜色属性

时间:2022-04-16 10:42:56

  颜色属性无处不在。字体要用颜色,背景可以有颜色,粒子特效更是离不开颜色。本文参考了一些资料简单总结下以备日后查阅。

  css中颜色的定义方式:

  1. 十六进制色
  2. RGB & RGBA
  3. HSL & HSLA
  4. 颜色名

十六进制色

  个人最喜欢的一种颜色表达方式。

  十六进制颜色是这样规定的:#RRGGBB,其中的RR(红色)、GG(绿色)、BB(蓝色)十六进制整数规定了颜色的成分。所有值必须介于 0 与 FF 之间。

  生成随机颜色:

function getRandomColor() {
  return '#' + ('00000' + parseInt(Math.random() * 0xffffff).toString(16)).slice(-6);
}

  猛戳CSS 颜色十六进制值查看具体颜色效果。

RGB和RGBA

  RGB 颜色值是这样规定的:rgb(red, green, blue)。每个参数 (red、green 以及 blue) 定义颜色的强度,可以是介于 0 与 255 之间的整数,或者是百分比值(从 0% 到 100%)。

  举例说,rgb(0,0,255) 值显示为蓝色,这是因为 blue 参数被设置为最高值(255),而其他被设置为 0。

  同样地,下面的值定义了相同的颜色:rgb(0,0,255) 和 rgb(0%,0%,100%)。

  RGBA 颜色值是 RGB 颜色值的扩展,带有一个 alpha 通道,它规定了对象的不透明度。

  RGBA 颜色值是这样规定的:rgba(red, green, blue, alpha)。alpha 参数是介于 0.0(完全透明)与 1.0(完全不透明)的数字。

  可以直观感受下RGBA: RGBA颜色展示

熟悉css/css3颜色属性

  如果看不到控件效果,请用chrome打开~

HSL和HSLA

  HSL 指的是 hue(色调)、saturation(饱和度)、lightness(亮度)- 表示颜色柱面坐标表示法。

  HSL 颜色值是这样规定的:hsl(hue, saturation, lightness)。

  Hue 是色盘上的度数(从 0 到 360) - 0 (或 360) 是红色,120 是绿色,240 是蓝色。可以看下面这张图感受下:

熟悉css/css3颜色属性

  Saturation 是百分比值;0%表示的是一个灰度,不使用任何的色彩,而100%是全彩,表示充分使用一个颜色。

  Lightness 同样是百分比值;0% 是黑色,100%是白色。

  可以直观感受下HSL(看不到效果请用chrome): HSL颜色展示

  HSLA 颜色值是 HSL 颜色值的扩展,带有一个 alpha 通道 - 它规定了对象的不透明度。

  HSLA 颜色值是这样规定的:hsla(hue, saturation, lightness, alpha),其中的 alpha 参数定义不透明度。alpha 参数是介于 0.0(完全透明)与 1.0(完全不透明)的数字。

  如果实际应用中我们需要让颜色变亮一点或者变暗一点,hsl是个不错的选择,比如说a:hover时颜色变亮,改变第三个参数值即可。

  利用hsl我们也能做一些动态的渐变效果,因为360颜色一循环。这个demo中的颜色就用了hsl(猛戳看demo

颜色名

  就是white、black、red等等这样的啦,其实还有更多,可以参考CSS 颜色名

总结

  • 关于兼容:
  1. 十六进制色(所有浏览器兼容)
  2. RGB(所有浏览器兼容)
  3. RGBA(ie下用滤镜兼容)
  4. HSL(不兼容ie)
  5. HSLA(不兼容ie)
  6. 颜色名(所有浏览器兼容)
  • 参考资料:
  1. CSS 合法颜色值
  2. CSS3 RGBA
  3. 玩转CSS3的颜色