Style Dictionary项目中处理Tokens Studio字体尺寸单位问题
问题背景
在使用Style Dictionary处理来自Tokens Studio for Figma的设计令牌时,开发者遇到了一个常见问题:无法为字体尺寸值自动添加px或rem单位。原始令牌数据如下所示:
"body": {
"value": "16",
"type": "fontSizes"
}
开发者期望的输出是带有单位的CSS变量,例如:
$sd-font-sizes-body: 16px;
但实际得到的输出却是不带单位的纯数字:
$sd-font-sizes-body: 16;
问题根源分析
这个问题源于Tokens Studio与DTCG(Design Token Community Group)规范在类型命名上的不一致:
- DTCG规范中定义字体尺寸的类型名称为
fontSize(单数形式) - Tokens Studio则使用了
fontSizes(复数形式)作为类型名称
Style Dictionary内置的size/px和size/rem转换器是按照DTCG规范实现的,因此只识别fontSize类型的令牌,而忽略了fontSizes类型的令牌。
解决方案
针对使用Tokens Studio生成的设计令牌,推荐以下解决方案:
-
使用专门为Tokens Studio设计的转换器
可以使用@tokens-studio/sd-transforms包中的ts/size/px转换器,这个转换器专门适配了Tokens Studio的类型命名约定。 -
配置转换器
在Style Dictionary配置文件中,将转换器从size/px替换为ts/size/px:"transforms": [ "attribute/cti", "name/cti/kebab", "time/seconds", "content/icon", "color/css", "ts/size/px" ]
深入理解
-
设计令牌类型系统
设计令牌的类型系统是确保转换器正确工作的关键。不同的工具可能对同一概念使用不同的类型名称,这是跨工具协作时常见的兼容性问题。 -
单位转换的重要性
自动添加单位是设计系统工作流中的重要环节,可以确保输出样式的一致性,避免开发者手动添加单位可能带来的错误。 -
转换器的工作机制
Style Dictionary的转换器是基于令牌类型进行匹配的。当类型名称不匹配时,转换器将不会对相应的令牌值进行处理。
最佳实践建议
-
统一工具链
如果项目中使用Tokens Studio作为设计输入,建议在整个工具链中使用专为它优化的转换器和插件。 -
明确类型约定
在团队内部明确设计令牌的类型命名规范,确保设计工具和开发工具使用相同的约定。 -
测试输出结果
在设置转换器后,应该验证生成的样式文件是否包含预期的单位,确保转换器按预期工作。
通过理解这些原理和解决方案,开发者可以更有效地使用Style Dictionary处理来自不同设计工具的设计令牌,确保输出结果符合预期。
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00