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,它为开发者提供了从传统设计向现代设计过渡的工具,同时保持了向后兼容性。这种渐进式的升级策略体现了对现有项目维护的考虑,同时也为采用新设计提供了清晰的路径。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0131
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
AgentCPM-ReportAgentCPM-Report是由THUNLP、中国人民大学RUCBM和ModelBest联合开发的开源大语言模型智能体。它基于MiniCPM4.1 80亿参数基座模型构建,接收用户指令作为输入,可自主生成长篇报告。Python00