Spectrum CSS 8.0.0版本发布:构建Spectrum 2设计系统基础
Spectrum CSS是Adobe开源的一套CSS框架,它为Adobe产品提供了一套完整的设计系统实现。这个框架包含了丰富的UI组件样式,帮助开发者快速构建符合Adobe设计规范的界面。最新发布的8.0.0版本是一个重要的里程碑,它引入了Spectrum 2 Foundations,为从Spectrum 1(S1)到Spectrum 2(S2)的设计过渡搭建了桥梁。
版本核心变化
8.0.0版本的主要创新在于创建了一个灵活的系统层,允许开发者在S1、Express和S2设计之间切换组件的外观。这一特性通过重新映射组件级别的token到适当的token数据集来实现,而不是提供一个完全迁移的S2组件。
要使用S2样式,开发者需要搭配使用16.0.0或更高版本的@spectrum-css/tokens。而对于S1或Express样式,则需要使用14.x或15.x版本的token包。这种设计为开发者提供了更大的灵活性,可以根据项目需求选择合适的视觉风格。
文件结构与使用建议
新版本对文件结构进行了优化:
- 移除了metadata文件夹及其内容,相关信息现在可以在每个组件的dist/metadata.json中找到
- 移除了已弃用的index-vars.css文件,建议使用index.css或index-base.css替代
对于不同的使用场景,开发人员可以灵活选择:
- 如果只需要S2 Foundations样式,使用index.css文件
- 如果只需要S1或Express组件样式,使用index-base.css配合相应的themes/(spectrum|express).css文件
- 如果需要在不同设计系统间切换,使用index-base.css配合index-theme.css文件,并通过.spectrum--legacy(S1)或.spectrum--express(Express)类来控制
技术实现细节
这一版本的实现依赖于系统层的token重映射机制。通过将组件级别的CSS变量与更高层级的token系统解耦,使得同一套组件可以在不同设计系统下呈现不同的视觉效果。这种架构设计既保证了代码的复用性,又提供了足够的灵活性。
兼容性考虑
值得注意的是,这个版本是为Spectrum Web Components 1.x设计的过渡方案。对于希望完全采用S2设计的项目,开发者应该考虑使用next标签的版本。这种分阶段的升级路径为大型项目提供了平滑过渡的可能性。
总结
Spectrum CSS 8.0.0版本的发布标志着Adobe设计系统演进的重要一步。通过引入Spectrum 2 Foundations,它为开发者提供了从传统设计向现代设计过渡的工具,同时保持了向后兼容性。这种渐进式的升级策略体现了对现有项目维护的考虑,同时也为采用新设计提供了清晰的路径。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0231
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
JoyAI-VL-Interaction-Preview京东开源首个开源、视觉驱动的实时交互模型——它能实时监控视频流,并自主决定何时发言、保持沉默或委托任务。Jinja00
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0151
kornia🐍 空间人工智能的几何计算机视觉库Python02
PaddleParallel Distributed Deep Learning: Machine Learning Framework from Industrial Practice (『飞桨』核心框架,深度学习&机器学习高性能单机、分布式训练和跨平台部署)C++02