CSS中使用 HSL(Hue, Saturation, Lightness) 动态生成色值

前言

HSL(Hue, Saturation, Lightness)是一种直观的颜色表示方法,比传统的RGB模式更符合人类对颜色的感知方式。下面我将详细介绍HSL颜色模式,并提供实际应用案例。

1、HSL颜色模式详解

1.1、 HSL的三个分量

1.1.1、色相(Hue):表示颜色的基本属性,取值范围0-360度

:红色
120° :绿色
240° :蓝色
360°:回到红色

1.1.2、饱和度(Saturation):表示颜色的纯度,取值范围0%-100%

0% :完全灰色(无色彩)
100%:完全饱和(颜色最鲜艳)

1.1.3、亮度(Lightness):表示颜色的明暗程度,取值范围0%-100%

0% :黑色
50% :纯色
100%:白色

2. HSL与RGB的比较

3、案例

由 红色 到绿色 分为100份,根据数据的大小进行色值改变

例如:

红色为:hsla(355, 65%, 46%, 1)

绿色为:hsla(148, 100%, 38%, 1)

javascript 复制代码
<template #stationNum-slot="{row}">
    <div class="my-cell-span" :style="{backgroundColor: `hsl(${(120 - row.stationNum * 1.2)}, ${(100 - (100 - 65) / 99) * row.stationNum}%, ${46 - ((46 - 38 ) / 99 ) * row.stationNum}%)`}">
        {{ row.stationNum }}
    </div>
</template>

// 色相(Hue):(120 - row.stationNum * 1.2),因为红色 0°:红色,120°:绿色; 或者 ${148 + ((355 - 148) / 99) * row.stationNum }
// 饱和度(Saturation): ${(100 - (100 - 65) / 99) * row.stationNum}%, 根据基础色的饱和度进行等份换算
// 亮度(Lightness): ${46 - ((46 - 38 ) / 99 ) * row.stationNum}%
...


const handleReload = () => {
let data = []
for(let i=1;i<101;i++){
    data.push({
        regionName: i,
        stationNum: Math.round((Math.random() * 100) + 1) 
    })
}
tabledata.value = data.sort((a, b) => b.stationNum - a.stationNum)
}

效果图片:这种色值过渡效果明显要比使用RGBA 展示的效果让人看着更舒服

4、HSL的优势和使用场景

4.1、优势

直观性 :HSL比RGB更符合人类对颜色的感知方式
易于调整 :只需调整一个分量即可改变颜色特性
创建和谐配色:通过固定色相,调整饱和度和亮度可以轻松创建和谐的颜色方案

4.2、使用场景

主题颜色系统 :使用HSL可以轻松创建主色、辅助色和强调色
颜色渐变 :通过调整色相创建平滑的颜色过渡
响应式颜色 :根据主题或状态调整颜色亮度和饱和度
可访问性:通过调整亮度对比度确保内容可读性

总结

HSL颜色模式提供了一种直观的方式来处理颜色,特别适合需要动态生成颜色或创建和谐配色方案的场景。通过固定色相并调整饱和度和亮度,可以轻松创建出一系列协调的颜色,非常适合设计系统和主题开发。

相关推荐
o***Z4481 天前
前端性能优化案例
前端
张拭心1 天前
前端没有实际的必要了?结合今年工作内容,谈谈我的看法
前端·ai编程
姜太小白1 天前
【前端】CSS媒体查询响应式设计详解:@media (max-width: 600px) {……}
前端·css·媒体
HIT_Weston1 天前
39、【Ubuntu】【远程开发】拉出内网 Web 服务:构建静态网页(二)
linux·前端·ubuntu
百***06011 天前
SpringMVC 请求参数接收
前端·javascript·算法
天外天-亮1 天前
Vue + excel下载 + 水印
前端·vue.js·excel
起个名字逛街玩1 天前
前端正在走向“工程系统化”:从页面开发到复杂产品架构的深度进化
前端·架构
用户47949283569151 天前
React 渲染两次:是 Bug 还是 Feature?聊聊严格模式的“良苦用心”
前端·react.js·前端框架
b***74881 天前
前端GraphQL案例
前端·后端·graphql
云飞云共享云桌面1 天前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑