CSS 提供了多种颜色表示方法,包括颜色名称、十六进制、RGB、RGBA、HSL、HSLA 等。理解这些颜色表示方法对于创建美观的网页至关重要。
颜色名称是 CSS 预定义的颜色关键词,可以直接使用英文名称来表示颜色。
/* 使用颜色名称 */
.text {
color: red;
}
.background {
background: blue;
}
.border {
border-color: green;
}
/* 基本颜色 */
.primary-red {
color: red;
}
.primary-green {
color: green;
}
.primary-blue {
color: blue;
}
/* 其他颜色 */
.yellow {
color: yellow;
}
.orange {
color: orange;
}
.purple {
color: purple;
}
/* 灰度颜色 */
.black {
color: black;
}
.white {
color: white;
}
.gray {
color: gray;
}
CSS 支持的颜色名称包括:
十六进制是最常用的颜色表示方法,使用 6 位十六进制数表示颜色,前两位表示红色,中间两位表示绿色,后两位表示蓝色。
/* 使用十六进制 */
.text {
color: #ff0000;
}
.background {
background: #0000ff;
}
.border {
border-color: #008000;
}
/* 简写形式 */
.text {
color: #f00; /* #ff0000 */
}
.background {
background: #00f; /* #0000ff */
}
.border {
border-color: #080; /* #008800 */
}
/* 红色 */
.red {
color: #ff0000;
}
/* 绿色 */
.green {
color: #00ff00;
}
/* 蓝色 */
.blue {
color: #0000ff;
}
/* 白色 */
.white {
color: #ffffff;
}
/* 黑色 */
.black {
color: #000000;
}
RGB 是红、绿、蓝三原色的组合,每个颜色的值范围是 0-255。
/* 使用 RGB */
.text {
color: rgb(255, 0, 0);
}
.background {
background: rgb(0, 0, 255);
}
.border {
border-color: rgb(0, 128, 0);
}
/* 红色 */
.red {
color: rgb(255, 0, 0);
}
/* 绿色 */
.green {
color: rgb(0, 255, 0);
}
/* 蓝色 */
.blue {
color: rgb(0, 0, 255);
}
/* 白色 */
.white {
color: rgb(255, 255, 255);
}
/* 黑色 */
.black {
color: rgb(0, 0, 0);
}
RGBA 是 RGB 的扩展,增加了透明度(Alpha)通道,透明度的值范围是 0-1,0 表示完全透明,1 表示完全不透明。
/* 使用 RGBA */
.text {
color: rgba(255, 0, 0, 1);
}
.background {
background: rgba(0, 0, 255, 0.5);
}
.border {
border-color: rgba(0, 128, 0, 0.8);
}
/* 半透明红色 */
.red-transparent {
color: rgba(255, 0, 0, 0.5);
}
/* 半透明蓝色 */
.blue-transparent {
background: rgba(0, 0, 255, 0.3);
}
/* 半透明绿色覆盖层 */
.overlay {
background: rgba(0, 128, 0, 0.7);
}
/* 半透明覆盖层 */
.modal-overlay {
background: rgba(0, 0, 0, 0.5);
}
/* 半透明按钮 */
.button {
background: rgba(0, 123, 255, 0.8);
}
/* 半透明边框 */
.input {
border-color: rgba(0, 0, 0, 0.2);
}
HSL 是色相、饱和度、亮度的组合:
/* 使用 HSL */
.text {
color: hsl(0, 100%, 50%);
}
.background {
background: hsl(240, 100%, 50%);
}
.border {
border-color: hsl(120, 100%, 25%);
}
/* 红色 */
.red {
color: hsl(0, 100%, 50%);
}
/* 绿色 */
.green {
color: hsl(120, 100%, 50%);
}
/* 蓝色 */
.blue {
color: hsl(240, 100%, 50%);
}
/* 白色 */
.white {
color: hsl(0, 0%, 100%);
}
/* 黑色 */
.black {
color: hsl(0, 0%, 0%);
}
/* 调整颜色的亮度 */
.light-blue {
color: hsl(240, 100%, 70%);
}
.dark-blue {
color: hsl(240, 100%, 30%);
}
/* 调整颜色的饱和度 */
.vibrant-blue {
color: hsl(240, 100%, 50%);
}
.muted-blue {
color: hsl(240, 50%, 50%);
}
HSLA 是 HSL 的扩展,增加了透明度(Alpha)通道,透明度的值范围是 0-1。
/* 使用 HSLA */
.text {
color: hsla(0, 100%, 50%, 1);
}
.background {
background: hsla(240, 100%, 50%, 0.5);
}
.border {
border-color: hsla(120, 100%, 25%, 0.8);
}
/* 半透明红色 */
.red-transparent {
color: hsla(0, 100%, 50%, 0.5);
}
/* 半透明蓝色 */
.blue-transparent {
background: hsla(240, 100%, 50%, 0.3);
}
/* 半透明绿色覆盖层 */
.overlay {
background: hsla(120, 100%, 25%, 0.7);
}
/* 颜色名称 */
.text {
color: red;
}
/* 十六进制 */
.text {
color: #ff0000;
}
/* 十六进制 */
.text {
color: #ff0000;
}
/* RGB */
.text {
color: rgb(255, 0, 0);
}
/* RGB */
.text {
color: rgb(255, 0, 0);
}
/* HSL */
.text {
color: hsl(0, 100%, 50%);
}
/* 推荐 - 使用颜色名称表示基本颜色 */
.button {
background-color: red;
}
.text {
color: blue;
}
/* 推荐 - 使用十六进制表示精确颜色 */
.button {
background-color: #007bff;
}
.text {
color: #333333;
}
/* 推荐 - 使用 RGB 表示需要计算的颜色 */
.button {
background-color: rgb(0, 123, 255);
}
.text {
color: rgb(51, 51, 51);
}
/* 推荐 - 使用 HSL 表示需要调整亮度和饱和度的颜色 */
.button {
background-color: hsl(211, 100%, 50%);
}
.text {
color: hsl(0, 0%, 20%);
}
/* 推荐 - 使用 RGBA 或 HSLA 表示半透明颜色 */
.overlay {
background-color: rgba(0, 0, 0, 0.5);
}
.button {
background-color: hsla(211, 100%, 50%, 0.8);
}
/* 推荐 - 使用十六进制 */
.button {
background-color: #007bff;
}
/* 不推荐 - 使用颜色名称 */
.button {
background-color: blue;
}
/* 推荐 - 使用 RGBA 或 HSLA */
.overlay {
background-color: rgba(0, 0, 0, 0.5);
}
/* 不推荐 - 使用 RGB */
.overlay {
background-color: rgb(0, 0, 0);
}
/* 推荐 - 使用 HSL 调整颜色 */
.light-blue {
color: hsl(240, 100%, 70%);
}
.dark-blue {
color: hsl(240, 100%, 30%);
}
CSS 提供了多种颜色表示方法:
记住以下几点: