如今,许多科技公司都开发了自己的 Bootstrap 版本,称为设计系统。这些是由明确的设计标准指导的可重用组件的集合,以支持应用程序开发,这使企业能够将他们的移动和 Web 应用程序与其他应用程序区分开来,同时保持产品的视觉外观和感觉,从 Bootstrap 到设计系统的演变是自然的。想要尽快掌握Web 应用程序技术,参加Web前端培训也是个不错的方法,几个月的学习就能掌握全面系统的知识和技能,快速上岗。
你有没有注意到同一家公司的两种不同产品可以有两种完全不同的用户体验?设计不一致通常来自两个独立的设计团队,它们不同步并独立构建自己的 UI 集。这就是设计系统可以提供帮助的地方。设计系统的目标应该是使开发人员和设计师能够通过在所有产品中提供一致的用户体验来创造引人入胜的产品体验。
最重要的是,设计系统不仅仅是 UI 组件库,而是标准和指南、视觉语言、可访问性支持以及如何开始实施系统的信息的文档。当然,这个列表并不详尽,但一个完整的设计系统并不止于构建一个 UI 库。
此外,设计系统使开发人员受益。作为工程师,你可以专注于解决技术问题或学习新技术,而不是构建冗余用户界面。如果你是前端开发人员,当多次要求你构建相同的 UI 组件时,你可能会感到沮丧。使用设计系统,组件只需构建一次,然后你就可以实现它。让我们看看设计系统如何帮助工程团队扩展。
系统思考规模
系统思维是一组原则,可帮助组织通过解决问题所在的整个系统来更有效地扩展。没有硬性规则,每个组织都应该制定自己的原则并将其与业务目标联系起来。设计系统目标是一种系统思维形式,可大规模解决设计挑战。在设计系统变得普遍之前,“设计无法扩展”的口号非常普遍。在Web前端培训中,有理论课程+实践项目一起学习,深化所学知识,积累项目经验,获得快速提升。
如果一个组织有一个产品组合,并且每个团队都在构建自己的资产,提出调色板和页面布局,那就不是很好地利用他们的时间。一遍又一遍地构建相同东西的开发人员将宝贵的时间从解决核心工程问题上浪费了,那些忙于为几个月前由其他团队构建的相同 UI 创建规范的设计师可以通过进行用户研究得到更好的服务。
从本质上讲,设计系统要成为一个活生生的、不断发展的系统,代表组织的最佳思维,它需要交付共享价值。要使组件可重用,它需要与多个产品团队相关。让设计系统团队参与构建仅特定于你的产品的组件不是系统思维。具有一次性案例的组件不应属于组件库或设计系统。
来自中央团队的支持
任何设计系统的核心都是设计和开发 UI 组件的中心团队。一个功能强大的设计系统团队遵循定义明确的流程来设计、构建和记录组件、视觉指南、工程指南和用户体验模式。
例如,在构建系统功能(例如,按钮组件)时,设计系统团队应通过对变量、大小和可组合性等项目进行初始设计发现来收集需求。在最初的发现之后,团队应该与想要使用该组件的开发人员分享他们的发现,以确保它具有发布后需要采用的所有功能。在这一点上,构建组件是容易的部分,但应该有关于设计、代码和可访问性的清晰文档来支持这个新元素。这些是设计系统团队的核心职责。
此外,该团队还负责修复错误、支持设计社区、创建培训材料等。设计系统应该被视为一个产品团队,其客户是内部设计师和前端工程师,专注于构建和扩展系统。想学习前端技术的同学可以参加Web前端培训,有系统全面的课程,还有经验丰富的专业讲师指导教学,可以快速掌握前端知识和技能,节省很多学习时间,少走弯路。
最后,团队负责采用。如果没有被其他团队采用,那么为了构建一个设计系统而构建一个设计系统是一种浪费的努力。有许多方法可以评估设计系统在组织内的影响,例如,设计系统团队可以扫描公司范围的代码库,以确定系统的使用位置和方式,这也有助于了解哪些团队正在使用最新版本的 UI 组件。
评估采用率的另一种方法是要求产品团队每季度自我报告他们的采用进度,这取决于组织的规模,设计系统团队还可以将调查与其他评估方法结合使用。通常有一名产品经理负责与其他利益相关者建立伙伴关系,他们创建开发路线图并将社区需求带回给设计人员和开发人员。
旨在帮助开发人员
设计系统旨在为前端开发人员提供他们的开发工作流程。
如果一个设计系统构建了组件,但无法分发它,它会让许多开发人员感到沮丧。或者,如果包是通过过时的包管理器分发的,这将使开发人员使用设计系统组件具有挑战性。一个好的设计系统会不断发展其分发工具,当今许多设计系统都普遍支持现代包管理器工具,例如 NPM 或 Yarn。参加Web前端培训,有明确清晰的学习路线,可以在短时间内尽快掌握web开发的相关知识,有助于你更好地进行开发工作。
此外,需要对组件进行正确的版本控制,并且需要经常更新发行说明以反映主要和次要版本的更改。许多设计系统通过围绕测试记录他们的过程来获得开发人员对组件稳定性的信心。
此外,开发人员关心样式封装以及代码的编译和转译。一些开发人员关心作用域 CSS 类名。许多设计系统使用 CSS 模块来模块化和组合 CSS,设计系统利用 CSS 模块来启用类名称的自定义范围,并防止不同版本之间的名称冲突,CSS 模块允许 UI 组件与其他版本的库在页面上共存。
设计系统可以帮助解决其他几个工程问题——JavaScript polyfill、对 Vue 或 React 框架的支持、使用 CDN 分发库资产、SCSS 后处理或覆盖、内置可访问性等等。关键是设计系统远远超出了视觉指南,支持工程任务是设计系统工作的一部分。
如果你发现你的团队一遍又一遍地构建相同的组件,那么也许是时候将你的设计系统化了。 借助设计系统,你的工程和设计团队之间的联盟可以有效地为最终用户构建一致的用户体验,并且可以轻松地跨多个产品和平台进行扩展。如果你想学习设计系统相关知识和技能,你可以从web前端培训课程开始,这是一个很好的起点。