`

CSS 颜色体系详解

阅读更多

说到 CSS 颜色,相比大家都不会陌生,本文是我个人对 CSS 颜色体系的一个系统总结与学习,分享给大家。

先列出目录直观的感受一下与 CSS 颜色相关大概覆盖了哪些内容。

 ①色彩关键字;

 ②transparent透明;

 ③currentColor当前color值;

 ④rgb()与rgba();

 ⑤hls()与hsla();

 ⑥兼容性

 

接下来的行文内容大概会按照这个顺序进行,内容十分基础,可选择性跳到相应内容处阅读。

(1)色彩关键字

色彩关键字很好理解。它表示一个具体的颜色值,且它不区分大小写。譬如这样 color:red 的 red 即是一个色彩关键字。

在 CSS3 之前,也就是 CSS2,一共包含了 17 个基本颜色。

而到了 CSS3,色彩关键字得到了极大的扩充,达到了 147 个。

 

哪些属性可以设置颜色

所有可以用到颜色值的地方,都可以用色彩关键字替代,那么在 CSS 中,什么地方可以用到颜色值呢?

①文本的颜色 color:red

②元素的背景色 background-color:red (包含各类渐变)

③元素的边框 border-color:red

④元素的盒阴影或文字阴影 box-shadow:0 0 0 1px red | text-shadow:5px 5px 5px red

⑤运用在一些滤镜当中 filter: drop-shadow(16px 16px 20px red)

⑥<hr /> 水平线的颜色

 

一些无法直接设置,但是可以被得到或者继承当前元素 currentColor 的属性:

⑦<img> 的 alt 文本。也就是,当无法显示图像时,代替图像出现的文本,会继承这个颜色值。

⑧ul 列表项的小点

 

一些比较常见的就不举例了,说一下 <hr/> 、 <img> 的 alt 文本和 ul 列表项的小点。

经过测试, <hr/>的颜色值,可以通过设置它的 border 的颜色值来表示。

<img> 的 alt 文本和 ul 列表项的小点则会继承当前元素 currentColor 的属性。

 

(2)transparent透明属性

 transparent 的字面意思就是透明。它用来表示一个完全透明的颜色,即该颜色看上去将是背景色,也可以理解为它是 rgba(0,0,0,0) 的简写。

值得注意的是:

在 CSS3 之前,transparent 关键字不是一个真实的颜色,只能用于 background-color 和 border-color中,表示一个透明的颜色。而在支持 CSS3 的浏览器中,它被重新定义为一个真实的颜色,transparent 可以用于任何需要 color 值的地方,像 color 属性。

 

那么这个透明值有什么用呢?简单列举一些例子:

      ①transparent 用于 border,绘制三角形,这算是 transparent 最常见的一个用法,用于绘制三角形。

三角形简单画法:

利用一个高宽为 0 的 div,设置它的 border ,当任意三边的 border 颜色为 transparent 时,则可以得到任意朝向的一个三角形。

像上文说的,由于 transparent 在低版本浏览器中(IE78)可以使用在 border、background 中,所以此方法兼容性很好,可以利用于很多场景。

 

      ②transparent 用于 border,实现增大点击热区

按钮是我们网页设计中十分重要的一环,而按钮的设计也与用户体验息息相关。

让用户更容易的点击到按钮无疑能很好的增加用户体验,尤其是在移动端,按钮通常都很小,但是有时由于设计稿限制,我们不能直接去改变按钮元素的高宽。那么这个时候有什么办法在不改变按钮原本大小的情况下去增加他的点击热区呢?

这里,借助透明的 border 可以轻松帮我们实现(利用伪元素也可以实现),利用一层透明的 border:20px solid transparent。

试着将光标靠近 Btn,会发现在还未到达有颜色区域之前,就已经触发了鼠标的交互响应事件 hover,利用这一点在移动端可以很好的扩大按钮的可点击区域又不至于改变按钮本身的形状。

这里我们将 border 用于了扩大鼠标点击区域,然而真实情况是有的时候我们的按钮必须要用到 border,而 border 又只能设置一重(无法像 box-shadow和 渐变一样设置多重 border),这个时候如果还需要运用这种方法,可以使用内阴影 box-shadow模拟一层 border

      ③transparent 用于 background,绘制背景图

 transparent 用于 background,绘制背景图

transparent 用于 background,通常可以制造出各种各样的背景图像。例如利用透明渐变,实现一个切角图形。

通过 线性渐变 linear-gradient 实现从透明色到实色的变化,将四个四分之一大小( background-size: 50% 50%)的图形组合在一起,就生成了一个切角图形。

利用 transparent 与渐变的配合还能生成各种各样美妙的图形,可以戳下面看看:

      ④transparent 用于文本 color

配合 box-shadow ,在文本上运用 transparent,可以营造出一种文字发光的效果,鼠标 hover 下面的文字试试:

transparent 其实还有很多作用,暂且说这么多。

 

 

(3)currentColor当前颜色

很多人都不知道还有 currentColor 这个东东。和 transparent 一样,它也是一个关键字,顾名思义,它表示当前颜色。它来自自属性或者继承于它的父属性。

可以简单的理解为当前 CSS 标签所继承或设定的文本颜色,即 color 的值。

 

那它具体可以怎么用呢,根据我们书写 CSS 的原则 DRY(Don’t Repeat Yourself),使用这个关键字可以很好的减少改动 CSS 时的工作量。

 

但是,currentColor 是 CSS3 新增的,在老版本浏览器下是无法识别的。那么是否在老版本浏览器下就无法使用了呢,也不尽然,还是有一些特例的,比如我只在 color 里写了颜色,border 的值为 1px solid,box-shadow 也是,并没有带上颜色值,但是依然表现为了 currentColor 的值。这是因为边框颜色和阴影颜色默认就是当前盒子的文本颜色,其中 border 兼容性很好,可以支持到 IE6 。

 

当然 border 和 box-shadow 是特例,不是所有需要填写颜色值的属性不填写都会默认继承文本的值的。

兼容:

 currentColorpollify

 

 

(4)rgb() 与 rgba()

rgb() 表示颜色的红-绿-蓝(red-green-blue (RGB))模式,rgba() 多一个 alpha透明度,取值为 0-1

 

我们知道,通常我们使用的时候,不使用缩写的话,使用十六进制符号 #RRGGBB,

在 #RRGGBB 中,RR 表示 红色的深浅,GG 表示绿色的深浅,BB 表示蓝色的深浅。取值都是从 00 - FF,值越大表示该颜色越深。

如果采用 rgb(RR,GG,BB) 的写法,RR 取值 0~255 或者百分比,255 相当于 100%,和十六进制符号里的 F 或 FF 。

了解了 rgb() 的含义的话,记住常用的颜色值其实是很容易的,像上面说的 RR 表示红色的深浅,那么理解记忆 #FF0000 表示为红色就 so easy 了,同理可以得到 #00FF00 表示蓝色, #0000FF表示绿色。

 

再记住颜色的叠加原理:

我们就可以轻松的记住, #FF00FF红蓝叠加表示紫色, #FFFF00红绿叠加表示黄色, #00FFFF蓝绿叠加表示青色。

 

 

(5)hsl() 与 hsla()

hsl()被定义为色相-饱和度-明度(Hue-saturation-lightness),hsla() 多一个 a ,表示其透明度,取值为 0-1。

①色相(H)是色彩的基本属性,就是平常所说的颜色名称,如红色、黄色等。

②饱和度(S)是指色彩的纯度,越高色彩越纯,低则逐渐变灰,取0-100%的数值。

③明度(V),亮度(L),取0-100%。

 

其实对于我们前端而言,使用 hsl 表示颜色会更方便。

以一个按钮为例:

我们用 hsl 颜色表示法表示按钮 normal 状态下的背景色值, hover 的时候背景色暗一点,而 active 的时候背景色亮一点。如果采用 rgb 表示法,我们需要 3 个完全不一样的颜色,而采用 hsl 表示法,我们只需要在 hover 和 active 的时候去改的 颜色值的 l (即Light,亮度)值即可。

比如这里 background:hsl(200, 60%, 60%) 在 hover 和 active 的时候,我只改动了 hsl 颜色值的第三个值达到了我们希望的效果

 

rgb 到 hsl 的转换

这里有个小 tips 可能有些人不知道,在开发阶段我们只有一个 rgb 值,但是希望转换成 hsl 值,使用 chrome 开发者工具可以很便捷的做到,如下图,我们只需要选中我们想转换的颜色值,按住键盘左 shift,点击这个颜色表示框,即可进行转换:

 

到此本文结束,比较基础,如果还有什么疑问或者建议,可以多多交流

 

 

.

分享到:
评论

相关推荐

    cnblogsArticle:自己博客园一些写得比较好的文章移植,欢迎订阅

    文章导航闲谈CSS 系列【CSS进阶】伪元素的妙用2 - 多列均匀布局及title属性效果【CSS进阶】CSS 颜色体系详解【CSS进阶】box-shadow 与 filter:drop-shadow 详解及奇技淫巧【CSS进阶】伪元素的妙用--单标签之美【CSS...

    CSS样式表的电子书

    《CSS样式表详解》 CSS,全称Cascading Style Sheets,中文译为层叠样式表,是网页设计中用于控制网页元素呈现样式的语言。它与HTML或XML(包括SVG、XHTML等)等结构语言配合使用,使得网页内容与表现分离,实现了...

    CSS1.pdf specification

    **CSS1:级联样式表第一级规范详解** 在深入探讨CSS1的细节之前,我们首先需要理解CSS(Cascading Style Sheets)的基本概念。CSS是一种用于控制网页外观的样式语言,它允许开发者以一种独立于文档内容的方式指定...

    HTML学习:css命名规则

    ### HTML学习:CSS命名规则详解 #### CSS命名规则概述 在HTML的学习过程中,掌握良好的CSS命名规则对于初学者来说非常重要。正确的命名不仅能够提高代码的可读性和可维护性,还能帮助开发者更快地理解样式结构,...

    微信小程序详解

    - **CSS**: CSS主要用于控制页面的样式,包括布局、颜色等。微信小程序中的CSS同样进行了定制化处理,支持一部分CSS3特性,并且增加了一些特有属性以适应微信平台的需求。 - **JavaScript**: JavaScript是实现逻辑的...

    Div+css布局大全学习手册

    ### Div+CSS布局大全学习手册知识点详解 #### Div+CSS布局概述 - **定义与重要性**:Div+CSS布局是一种使用HTML中的`&lt;div&gt;`标签结合CSS样式表来进行网页排版的方式。这种方式相较于传统的表格布局更为灵活且易于...

    android课程体系

    ### Android课程体系详解 #### 一、课程概览 本课程体系主要针对希望从事Java Android开发工作的学习者设计,旨在全面覆盖从基础到高级的所有关键技能。课程内容分为六个主要阶段,逐步深入地介绍了HTML、CSS、...

    Head First HTML with CSS and XHTML.pdf英文版,彩印

    通过本书的学习,无论是初学者还是有一定基础的学习者都能获得全面而系统的知识体系,从而在网页设计领域迈出坚实的步伐。此外,本书还强调了随着网络标准的发展和技术的进步,高质量编码的重要性日益凸显,因此鼓励...

    web网页设计期末课程大作业 基于HTML+CSS仿苹果商城电商项目的设计与实现

    - CSS3负责美化页面,通过样式表控制布局、颜色、字体等外观属性,实现丰富的视觉效果。 - JavaScript实现动态效果,如鼠标滑过特效、轮播图切换等功能。 - 使用外部CSS文件(如`iPads.css`),便于样式管理与...

    java web开发

    在Java Web开发中,CSS起着至关重要的作用,因为它负责网页的布局、颜色、字体、动画等视觉效果,使网页呈现出美观且用户友好的界面。 学习CSS深入详解,通常会涵盖以下知识点: 1. CSS选择器:学习如何选择和定位...

    《web结课作业的源码》中华传统文化题材网页设计主题——基于HTML+CSS+JavaScript精美自适应绿色茶叶公司

    - **CSS样式文件**: 控制页面的颜色、字体大小、位置等外观属性。 - **JavaScript文件**: 实现动态效果和用户交互功能。 - **图片文件**: 含有网站使用的各种图像资源。 #### 5. 网页编辑工具 - **Dreamweaver**: ...

    2021-2022计算机二级等级考试试题及答案No.17598.docx

    CSS 属性——改变文本颜色 - **题目描述**:给出的题目要求考生选择正确的CSS属性,该属性用于更改HTML元素的文本颜色。 - **知识点详解**: - `text-color`:这不是一个有效的CSS属性,CSS中并没有直接命名为`...

    王者荣耀攻略页面半成品.rar

    《王者荣耀攻略页面制作详解》 在网页设计领域,HTML、CSS和JavaScript是构建动态和交互式网站的基础。这里我们探讨的项目是“王者荣耀攻略页面半成品”,这是一个利用这些技术进行的实战练习。这个项目虽然尚未...

    web网页设计—— 指环王:护戒使者(13页) 电影网页设计 在线电影制作 个人设计web前端大作业

    ### 知识点详解 #### 一、网页设计与布局 - **网页简介与目标**: - 本项目是一个面向大学生的HTML静态网页设计作业,旨在帮助学生掌握基本的网页设计技能,如使用HTML与CSS进行布局设计,并且通过实践加深对网页...

    zencart网站模板

    《ZenCart网站模板详解》 ZenCart是一款开源的电子商务解决方案,专为小型企业和在线商家设计。它基于PHP语言,搭配MySQL数据库,提供了一个强大的后台管理系统,使得非技术背景的用户也能轻松搭建和管理网上商店。...

    零基础学习PHP-从零开始学习PHP-PHP基础教程-PHP简明教程.pdf

    - **层叠样式表(CSS)的作用**:CSS用于定义HTML页面的外观属性,如字体、颜色、布局等,它独立于HTML文档,通过外部文件链接或内联样式控制页面样式,使页面设计更灵活、更易于维护。 - **HTML文档示例**:HTML...

Global site tag (gtag.js) - Google Analytics