title | spline |
---|---|
主题配置 |
explain |
TDesign 通用的 Design Token 均使用 CSS Variables 声明,我们推荐使用替换 CSS Variables 的方式来进行个性化的主题配置。
TDesign 提供五大类 Design Token,包括颜色
、字体
、圆角
、阴影
及尺寸
,你可以在自己的项目中声明同名 CSS Variables来覆盖他们的值,如:
--td-brand-color: orange;
--td-warning-color: yellow;
--td-error-color: red;
--td-success-color: green;
完整的 Token 列表见 TDesign Design Token。
因为涉及到的 Token 数量很多,我们提供了更直观的基于 CSS Token 实现的主题配置生成器
,来帮助您快速定制您需要的主题。您可以通过点击官网右下角的按钮
打开我们的主题配置生成器。
通过主题配置生成器配置出您满意的 Token 之后,请点击导出主题配置
,我们会导出一份全新的 CSS 文件到您本地,您只需要将文件放置进您的项目文件目录中,并在项目中 import 该 CSS 文件,即可得到一个全新主题样式的 TDesign 。
如果你的项目也使用 less 技术栈,且对组件有更精细的定制需求,我们也抽离了大部分组件实现过程中用到的变量,以 less 变量的方式提供出来,
// 以 Button 为例
@btn-height-s: 24px;
@btn-height-default: 32px;
@btn-height-l: 40px;
@btn-border-radius: @border-radius-default;
要修改这些 less 变量,需要改为从 npm ESM 产物中引入组件库:
// tdesign-npm-name 替换为当前在使用的包名称
import TDesign from "tdesign-npm-name/esm";
// 引入组件库全局样式资源
import "tdesign-npm-name/esm/style/index.js";
关于各类构建产物的差别可以参考 构建产物规范。
之后,你可以在自己的项目自行修改这些变量的值,比如使用 modifyVars :
{
loaderOptions: {
less: {
lessOptions: {
modifyVars: {
'@brand-color': '#ebb105',
},
javascriptEnabled: true,
},
},
}
}