颜色系统
ThemePro 提供了强大而灵活的颜色系统,用于管理应用中的所有颜色,确保视觉一致性和主题切换的流畅体验。
颜色系统概述
ThemePro 的颜色系统基于以下几个核心概念:
- 基础主题颜色 - 定义整个主题的基调
- 变体颜色 - 语义化的颜色变体(primary、success、warning、danger、info)
- 渐变色系 - 基于基础颜色自动生成的渐变色系
- CSS 变量 - 通过 CSS 变量实现颜色的统一管理和动态切换
颜色变量命名规则
ThemePro 使用以下命名规则定义颜色变量:
--t-color-theme-{n}
- 主题基础颜色系列,n 为 0-10 的数字,表示不同亮度级别--t-color-{variant}-{n}
- 变体颜色系列,variant 为变体名称,n 为 0-10 的数字--t-{variant}-color
- 变体文本颜色--t-{variant}-bgcolor
- 变体背景颜色--t-{variant}-bgcolor-{n}
- 变体背景颜色的不同亮度级别
渐变色生成
ThemePro 使用 generateGradientColors
函数根据基础颜色自动生成渐变色系:
js
import { generateGradientColors } from 'themepro';
const { colors, dark } = generateGradientColors({
color: '#3366ff', // 基础颜色
range: [10, 98], // 亮度范围
count: 5 // 生成颜色数量
});
console.log(colors); // 输出生成的颜色数组
生成的渐变色会根据基础颜色的明暗自动调整:
- 如果基础颜色是亮色,渐变是从亮到暗
- 如果基础颜色是暗色,渐变是从暗到亮
自定义颜色处理
在创建主题时,你可以提供自定义的颜色生成函数:
js
themePro.create({
// ...其他配置
onGenerateGradientColors: (options) => {
// 自定义颜色生成逻辑
const { color, range, dark } = options;
// 返回自定义的颜色数组
return ['#color1', '#color2', '#color3', ...];
}
});
可用颜色
以下颜色变量可以直接使用,与主题切换无关。
loading