当前位置: 首页 > article >正文

HTML 颜色全解析:从命名规则到 RGBA/HSL 值,附透明度设置与场景应用指南

一、HTML 颜色系统详解

HTML 中的颜色可以通过多种方式定义,包括颜色名称、RGB 值、十六进制值、HSL 值等,同时支持透明度调整。以下是详细分类及应用场景:


1. 颜色名称(预定义关键字)
HTML 预定义了 140 个标准颜色名称,如 red、blue、green 等,这些名称是浏览器直接支持的关键字。

示例:

<p style="color: tomato;">这是番茄红文本</p>
<div style="background-color: papayawhip;">这是番木瓜色背景</div>
  • 优点:简单易记,无需计算
  • 缺点:颜色范围有限,无法精确控制色调

常见名称:
  基础色:red、blue、green、yellow、black、white
  中性色:gray/grey、silver、navy、maroon
  特色色:tomato、lavender、coral、teal

注意:颜色名称不区分大小写,但建议使用小写以保持一致性。


2. RGB 表示法
RGB(Red, Green, Blue)通过三个 0-255 的数值表示颜色,格式为 rgb(红, 绿, 蓝)。

示例:

<p style="color: rgb(255, 0, 0);">纯红色</p> <!-等同于 red -->
<div style="background-color: rgb(128, 128, 128);">中灰色</div>
  • 优点:精确控制颜色,覆盖全色域
  • 缺点:数值记忆困难,需借助工具生成

透明度支持:使用 rgba(红, 绿, 蓝, 透明度),如:

<div style="background-color: rgba(0, 0, 255, 0.5);">半透明蓝色</div>

透明度值范围为 0.0(完全透明) 到 1.0(完全不透明)。


3. 十六进制表示法
十六进制颜色是最常用的表示法,格式为 RRGGBB 或 RGB(简写形式)。

示例:

<p style="color: FF0000;">纯红色</p> <!-等同于 rgb(255, 0, 0) -->
<div style="background-color: 808080;">中灰色</div>

简写规则:当两位数值相同时可缩写,如 FF0000 可写成 F00
透明度支持:使用 8 位表示法 RRGGBBAA,如:

<div style="background-color: 0000FF80;">半透明蓝色(80 表示约 50% 透明度)</div>

透明度范围为 00(完全透明) 到 FF(完全不透明)。


4. HSL 表示法
HSL(Hue, Saturation, Lightness)即色相、饱和度、亮度,格式为 hsl(色相, 饱和度%, 亮度%)。

示例:

<p style="color: hsl(0, 100%, 50%);">纯红色(色相 0°)</p>
<div style="background-color: hsl(120, 100%, 25%);">深绿色</div>

参数说明:

  • 色相(Hue):0-360 度的色轮值(0=红,120=绿,240=蓝)
  • 饱和度(Saturation):0%(灰色)到 100%(纯色彩)
  • 亮度(Lightness):0%(黑色)到 100%(白色),50% 为标准亮度

透明度支持:使用 hsla(色相, 饱和度%, 亮度%, 透明度),如:

<div style="background-color: hsla(180, 100%, 50%, 0.3);">半透明青色</div>

二、颜色应用场景与最佳实践

1. CSS 中的颜色应用
颜色可用于文本、背景、边框等多种 CSS 属性:

/* 文本颜色 */
p {color: 333; /* 深灰色文本 */
}/* 背景颜色 */
.header {background-color: rgba(0, 0, 0, 0.8); /* 半透明黑色背景 */
}/* 边框颜色 */
.card {border: 2px solid hsl(210, 100%, 50%); /* 蓝色边框 */
}/* 渐变背景 */
.gradient {background: linear-gradient(to right, ff9a9e, fad0c4); /* 粉色到米色渐变 */
}

2. 响应式颜色方案
根据设备或主题切换颜色:

/* 深色模式 */
@media (prefers-color-scheme: dark) {body {background-color: 1a1a1a;color: f0f0f0;}
}/* 浅色模式 */
@media (prefers-color-scheme: light) {body {background-color: ffffff;color: 333333;}
}

3. 动态颜色计算
使用 CSS 变量和 JavaScript 动态调整颜色:

<style>:root {--primary-color: 4a90e2; /* 主色调 */}.button {background-color: var(--primary-color);color: white;}
</style><script>// 根据用户操作动态修改颜色document.documentElement.style.setProperty('--primary-color', 'e24a4a');
</script>

4. 无障碍与对比度
确保文本与背景的颜色对比度符合 WCAG 标准(至少 4.5:1):

/* 良好的对比度示例 */
.danger-text {color: ff3333; /* 明亮的红色 */background-color: ffffff; /* 白色背景 */
}/* 不良的对比度示例(避免) */
.warning-text {color: aaaaaa; /* 浅灰色 */background-color: f0f0f0; /* 浅灰色背景 */
}

三、颜色工具与资源

1. 颜色选择器:
   Chrome DevTools 内置颜色选择器
   [Coolors](https://coolors.co/):生成配色方案
   [Color Hunt](https://colorhunt.co/):获取流行配色

2. 对比度检查工具:
   [WebAIM Contrast Checker](https://webaim.org/resources/contrastchecker/)
   [Chrome Lighthouse](https://developers.google.com/web/tools/lighthouse)

3. 颜色命名参考:
   [HTML Color Names](https://www.w3schools.com/colors/colors_names.asp)
   [CSS Color Keywords](https://developer.mozilla.org/en-US/docs/Web/CSS/color_valuecolor_keywords)


四、常见误区与注意事项

1. 避免使用纯黑色文本:

 /* 不推荐 */body {color: 000000; /* 纯黑色 */}/* 推荐 */body {color: 333333; /* 深灰色,更易阅读 */}

2. 慎用高饱和度颜色:
   明亮的纯色(如 FF0000)可能导致视觉疲劳,建议降低饱和度或亮度。

3. 避免颜色依赖:
   不要仅通过颜色传达信息(如“红色表示错误”),需结合图标或文本提示。

4. 响应式颜色适配:
   深色模式下,需重新测试颜色对比度和可读性。


五、总结

  • HTML 颜色系统提供了多种表示方法,开发者可根据场景选择合适的方式:
  • 颜色名称:简单场景,快速开发
  • RGB/RGBA:精确控制颜色与透明度
  • 十六进制:简洁且广泛使用,支持透明度缩写
  • HSL/HSLA:直观调整色相、饱和度和亮度

在实际应用中,需兼顾视觉效果与无障碍标准,合理使用 CSS 变量和媒体查询实现动态颜色方案,为用户提供一致且舒适的视觉体验。

相关文章:

HTML 颜色全解析:从命名规则到 RGBA/HSL 值,附透明度设置与场景应用指南

一、HTML 颜色系统详解 HTML 中的颜色可以通过多种方式定义&#xff0c;包括颜色名称、RGB 值、十六进制值、HSL 值等&#xff0c;同时支持透明度调整。以下是详细分类及应用场景&#xff1a; 1. 颜色名称&#xff08;预定义关键字&#xff09; HTML 预定义了 140 个标准颜色名…...

蓝桥杯12届国B 完全日期

题目描述。 如果一个日期中年月日的各位数字之和是完全平方数&#xff0c;则称为一个完全日期。 例如&#xff1a;2021 年 6 月 5 日的各位数字之和为 20216516&#xff0c;而 16 是一个完全平方数&#xff0c;它是 4 的平方。所以 2021 年 6 月 5 日是一个完全日期。 例如&…...

深度剖析多模态大模型中的视频编码器算法

写在前面 随着多模态大型语言模型(MLLM)的兴起,AI 理解世界的能力从静态的文本和图像,进一步拓展到了动态的、包含丰富时空信息的视频。视频作为一种承载了动作、交互、场景变化和声音(虽然本文主要聚焦视觉部分)的复杂数据形式,为 MLLM 提供了理解真实世界动态和因果关…...

游戏引擎学习第282天:Z轴移动与摄像机运动

运行游戏&#xff0c;展示目前进展 我们目前正在进行一个游戏开发项目。昨天&#xff0c;我们实现了基于房间的角色移动系统&#xff0c;并且加入了摄像机的跟随滚动功能。这是我们首次进入“游戏逻辑设计”阶段&#xff0c;也就是说&#xff0c;我们开始构建游戏本身的行为和…...

C++中的std::allocator

C中的std::allocator 文章目录 C中的std::allocator1.std::allocator1.1C中的placement new 和operator new1.2一个custom allocator的实现1.3使用std::allocator_traits实现allocator 1.std::allocator C中的std::allocator默默工作在CSTL中的所有容器的内存分配上&#xff0…...

Git/GitLab日常使用的命令指南来了!

在 GitLab 中拉取并合并代码的常见流程是通过 Git 命令来完成的。以下是一个标准的 Git 工作流&#xff0c;适用于从远程仓库&#xff08;如 GitLab&#xff09;拉取代码、切换分支、合并更新等操作。 &#x1f310; 一、基础命令&#xff1a;拉取最新代码 # 拉取远程仓库的所…...

aws 实践创建policy + Role

今天Cyber 通过image 来创建EC2 的时候,要添加policy, 虽然是administrator 的role, 参考Cyber 提供的link: Imageshttps://docs.cyberark.com/pam-self-hosted/14.2/en/content/pas%20cloud/images.htm#Bring 1 Step1:...

[Java实战]Spring Boot 解决跨域问题(十四)

[Java实战]Spring Boot 解决跨域问题&#xff08;十四&#xff09; 一、CORS 问题背景 什么是跨域问题&#xff1f; 当浏览器通过 JavaScript 发起跨域请求&#xff08;不同协议、域名、端口&#xff09;时&#xff0c;会触发同源策略限制&#xff0c;导致请求被拦截。 示例场…...

【HarmonyOS 5】鸿蒙星闪NearLink详解

【HarmonyOS 5】鸿蒙星闪NearLink详解 一、前言 鸿蒙星闪NearLink Kit 是 HarmonyOS 提供的短距离通信服务&#xff0c;支持星闪设备间的连接、数据交互。例如&#xff0c;手机可作为中心设备与外围设备&#xff08;如鼠标、手写笔、智能家电、车钥匙等&#xff09;通过星闪进…...

Python高级进阶:Vim与Vi使用指南

李升伟 整理 在 Python 高级进阶中&#xff0c;使用 Vim 或 Vi 作为代码编辑器可以显著提升开发效率&#xff0c;尤其是在远程服务器开发或快速脚本编辑时。以下是关于它们在 Python 开发中的高级应用详解&#xff1a; 1. Vim/Vi 简介 Vi&#xff1a;经典的 Unix 文本编辑器…...

【Python】对象生命周期全解析

Python对象生命周期全解析 在Python中&#xff0c;一个对象从创建到销毁会经历一系列过程&#xff0c;理解这些过程对于编写高效、可靠的Python代码非常重要。下面我将详细讲解Python对象的完整生命周期。 1. 对象创建阶段 (1) 内存分配 当使用类实例化时(obj MyClass())&…...

自然语言处理(NLP)在影评情感分析中的处理流程示例

自然语言处理&#xff08;NLP&#xff09;在影评情感分析中的处理流程示例 以影评情感分析为例&#xff0c;为你详细介绍自然语言处理的处理流程。在这个例子中&#xff0c;我们将使用 Python 和一些常用的 NLP 库&#xff0c;如nltk&#xff08;自然语言工具包&#xff09;和…...

WF24 wifi/蓝牙模块串口与手机蓝牙通信

usb-ttl ch340接线 打开串口工具SSCOM&#xff0c;端口号选择ch340接的那个口&#xff0c;波特率改成115200 DX-SMART_2.0.5.apk下载 手机打开DX-SMART软件 点击透传-搜索BLE-连接WF24-BLE 连接成功串口会收到消息 [14:37:10.591]收←◆ BLE_CONNECT_SUCCESS发送命令ATBLUFI…...

互联网大厂Java求职面试:优惠券服务架构设计与AI增强实践-3

互联网大厂Java求职面试&#xff1a;优惠券服务架构设计与AI增强实践-3 场景背景 面试场景设定在一家大型互联网公司&#xff0c;面试官为拥有10年以上经验的技术总监&#xff0c;专注于高并发、高可用系统的架构设计。候选人郑薪苦是一名技术潜力十足的程序员&#xff0c;擅…...

C++核心编程--1 内存分区模型

C程序执行时&#xff0c;内存可以划分为4部分 代码区&#xff1a;存放函数体的二进制代码 全局区&#xff1a;存放全局变量、静态变量、常量 栈区&#xff1a;局部变量、函数参数值&#xff0c;编译器自动分配和释放 堆区&#xff1a;程序员自己分配和释放 1.1 程序运行前…...

02_线性模型(回归分类模型)

用于分类的线性模型 线性模型也广泛应用于分类问题&#xff0c;可以利用下面的公式进行预测&#xff1a; $ \widehat y w[0]*x[0]w[1]*x[1]…w[p]*x[p]b > 0$ 公式看起来与线性回归的公式非常相似&#xff0c;但没有返回特征的加权求和&#xff0c;而是为预测设置了阈值…...

通义千问席卷日本!开源界“卷王”阿里通义千问成为日本AI发展新基石

据日本经济新闻&#xff08;NIKKEI&#xff09;报道&#xff0c;通义千问已成为日本AI开发的新基础&#xff0c;其影响力正逐步扩大&#xff0c;深刻改变着日本AI产业的格局。 同时&#xff0c;日本经济新闻将通义千问Qwen2.5-Max列为全球AI模型综合评测第六名&#xff0c;不仅…...

流程编辑器Bpmn与LogicFlow学习

工作流技术如何与用户交互结合&#xff08;如动态表单、任务分配&#xff09;处理过 XML 与 JSON 的转换自定义过 bpmn.js 的样式&#xff08;如修改节点颜色、形状、图标&#xff09;扩展过上下文菜单&#xff08;Palette&#xff09;或属性面板&#xff08;Properties Panel&…...

Figma 新手教程学习笔记

&#x1f4fa; 视频地址&#xff1a;Figma新手教程2025&#xff5c;30分钟高效掌握Figma基础操作与UI设计流程_哔哩哔哩_bilibili &#x1f9ed; 课程结构 Figma 简介&#xff08;00:38&#xff09; 熟悉工作环境&#xff08;01:49&#xff09; 操作界面介绍&#xff08;03:…...

RabbitMQ的工作队列模式和路由模式有什么区别?

RabbitMQ 的工作队列模式&#xff08;Work Queues&#xff09;和路由模式&#xff08;Routing&#xff09;是两种不同的消息传递模式&#xff0c;主要区别在于消息的分发逻辑和使用场景。以下是它们的核心差异&#xff1a; 1. 工作队列模式&#xff08;Work Queues&#xff09…...

什么是 ANR 如何避免它

一、什么是 ANR&#xff1f; ANR&#xff08;Application Not Responding&#xff09; 是 Android 系统在应用程序主线程&#xff08;UI 线程&#xff09;被阻塞超过一定时间后触发的错误机制。此时系统会弹出一个对话框提示用户“应用无响应”&#xff0c;用户可以选择等待或强…...

配置Spark环境

1.上传spark安装包到某一台机器&#xff08;自己在finaShell上的机器&#xff09;。 2.解压。 把第一步上传的安装包解压到/opt/module下&#xff08;也可以自己决定解压到哪里&#xff09;。对应的命令是&#xff1a;tar -zxvf 安装包 -C /opt/module 3.重命名。进入/opt/mo…...

嵌入式硬件篇---IIC

文章目录 前言1. IC协议基础1.1 物理层特性两根信号线SCLSDA支持多主多从 标准模式电平 1.2 通信流程起始条件&#xff08;Start Condition&#xff09;从机地址&#xff08;Slave Address&#xff09;应答&#xff08;ACK/NACK&#xff09;数据传输&#xff1a;停止条件&#…...

Window下Jmeter多机压测方法

1.概述 Jmeter多机压测的原理&#xff0c;是通过单个jmeter客户端&#xff0c;控制多个远程的jmeter服务器&#xff0c;使他们同步的对服务器进行压力测试。 以此方式收集测试数据的好处在于&#xff1a; 保存测试采样数据到本地机器通过单台机器管理多个jmeter执行引擎测试…...

视频图像压缩领域中 DCT 的 DC 系数和 AC 系数详解

引言 在数字图像与视频压缩领域&#xff0c;离散余弦变换&#xff08;Discrete Cosine Transform, DCT&#xff09;凭借其卓越的能量集中特性&#xff0c;成为JPEG、MPEG等国际标准的核心技术。DCT通过将空域信号映射到频域&#xff0c;分离出DC系数&#xff08;直流分量&…...

K8S cgroups详解

以下是 Kubernetes 中 cgroups&#xff08;Control Groups&#xff09; 的详细解析&#xff0c;涵盖其核心原理、在 Kubernetes 中的具体应用及实践操作&#xff1a; 一、cgroups 基础概念 1. 是什么&#xff1f; cgroups 是 Linux 内核提供的 资源隔离与控制机制&#xff0c…...

能源设备数据采集

在全球可持续发展目标与环境保护理念日益深入人心的时代背景下&#xff0c;有效管理和优化能源使用已成为企业实现绿色转型、提升竞争力的关键路径。能源设备数据采集系统&#xff0c;作为能源管理的核心技术支撑&#xff0c;通过对各类能源生产设备运行数据的全面收集、深度分…...

Go语言安装proto并且使用gRPC服务(2025最新WINDOWS系统)

1.protobuf简介 protobuf 即 Protocol Buffers&#xff0c;是一种轻便高效的结构化数据存储格式&#xff0c;与语言、平台无关&#xff0c;可扩展可序列化。protobuf 性能和效率大幅度优于 JSON、XML 等其他的结构化数据格式。protobuf 是以二进制方式存储的&#xff0c;占用空…...

[Linux性能优化] 线程卡顿优化。Linux加入USB(HID)热插拔线程占用CPU优化。Linux中CPU使用率过高优化

文章目录 [Linux性能优化] 线程卡顿优化。0、省流版本一、问题定位&#xff1a;CPU 资源分析二、线程卡顿现场复现线程优化前图片 三、线程卡顿优化方向1.如果是轮询方式2.如果是事件驱动方式 四、修改方式线程优化后图片 [Linux性能优化] 线程卡顿优化。 0、省流版本 如果采…...

Ubuntu20.04下如何源码编译Carla,使用UE4源码开跑,踩坑集合

一、简介 作为一个从事算法研究的人员,无人驾驶仿真一直是比较重要的一部分,但是现在比较常见的算法验证都是在carla这个开源仿真平台上做的,所以我有二次开发carla的需求,今天就来讲讲编译CARLA。 网上的教材很多,但还是推荐大家看官网教程:Linux build - CARLA Simul…...