盒马跨端设计系统 ReX Design For OS

简介: 6 个月前,在 D2 前端技术论上我们向社区分享了《盒马中后台跨端方案》,详细介绍了我们在基于盒马实体零售数字化业务场景中,面向盒马营运数字化系统构建的跨端设计系统——ReX Design For OS。6 个月来,在开发资源极度紧张的状态下,我们持续建设和打磨,今天我们很高兴的告诉大家我们已经将项目的主要代码开源到了 Github,并发布了 beta 版本。
来源:Alibaba F2E公众号
作者:景庄

6 个月前,在 D2 前端技术论上我们向社区分享了《盒马中后台跨端方案》,详细介绍了我们在基于盒马实体零售数字化业务场景中,面向盒马营运数字化系统构建的跨端设计系统——ReX Design For OS。6 个月来,在开发资源极度紧张的状态下,我们持续建设和打磨,今天我们很高兴的告诉大家我们已经将项目的主要代码开源到了 Github,并发布了 beta 版本。

在盒马,不同于传统的中后台场景,场的载体更加多样化,除了典型的办公室场景,还包括门店,仓库,配送站,以及移动中的卡车与电瓶车。在各类作业场景下,不同的作业人员可以借助多样化的作业设备执行作业任务,例如在门店经营作业中,小二可以通过 PC 查看经营报表,使用手机获取消息,使用平板电脑管理餐饮档口,使用扫码枪进行拣货作业,并且各项作业任务通常还会联动各类的打印设备,IOT 设备等等。

围绕这样的业务场景,传统的多端多套设计体系会导致多端分裂的用户体验,另一方面,也会导致高昂的研发成本。基于这样的事实,我们重新思考,并构建了一套多端统一的设计体系,在开发侧通过一套代码,多端可用的方式来支持多端业务研发,让开发者获得多端一致的开发体验,从而有效的提高多端场景的交付效能和用户体验。

面向多端设计,而不是单一设备

传统的中后台场景大多面向 PC 单一场景设计,即使有移动端诉求,也都是单独出一套移动端的设计规范,少有从多端视角来思考统一的设计体系。在盒马的营运场景中,移动设备和手势交互设备已成为员工作业过程中不可或缺的设备。因此,当我们思考中后台设计时,我们就需要站在更高的视角去看跨设备的设计体系 —— 面向多端设计,而不是单一的设备。

在考虑了盒马作业环境特殊性的基础上,我们认为面向多端设计,就需要考虑作业环境和作业类型的差异,实际的用户体验受到作业场景下的环境因素的制约。我们将这些环境因素归结为四大类,分别是人为因素、机器因素、任务因素、现场环境因素。并核心抽取了其中的操作态、屏幕尺寸、交互形态、信息密度、光线环境作为我们构建多端设计系统核心考虑的因素。

image.png

有了基本的设计思路后,我们考虑将这种设计思路以公式化的方式与 UI 系统的实现过程进行连接。通过拆解环境因子与设计因子之间的关联,我们可以通过建立基于一定数学规则的配置化系统,来实现面向差异化设备的 UI 规则的自动输出能力。配置化系统产出的设计规则包则可以被前端 UI 组件直接消费,从而实现面向端的 UI 差异化能力。

建立在设计侧统一多端的设计规则的基础上,我们建立了基于环境因子(Environment Token)的设计因子(Design Token)推导系统。

下图:基于基本环境变量的设计规则配置系统

image.png

详细内容可以参考:https://alibaba.github.io/rex-design/design

一套代码,多端可用

在开发侧,我们重新起航,实现了一套服务盒马新零售场景基本多端需求的跨端组件体系,提供一套代码,多端适配,多端可用。Rexd 的组件体系不再单一的面向单一设备能力进行实现,而是默认面向多种交互场景,提供统一的设备能力(Viewport, Pointers, Keyboard, Sensors, Network Speed)插拔,从而提供与设备匹配的组件层能力。对于组件使用者而言,不再需要区分 PC 页面开发,还是 Mobile 页面开发,提供一致的 API 理解和编码习惯,从而建立统一的开发心智,降低移动端的介入门槛。除此之外,在工程侧,我们还为多端应用的开发提供相应的应用开发工具的支持。

图:Rexd 组件在不同 Web Viewport 中的演示

详细内容可以参考:https://alibaba.github.io/rex-design/docs/

轻量的主题化逻辑

Rexd 主张只进行框架层的全局配置,从而为多端场景提供更加轻量级和低成本的主题配置方案。我们将整个视觉系统拆分为 色彩(colors)、字号(fontSizes)、sizes(通用尺寸)、space(间距)、边框(borders)、圆角(radii)、阴影(shadows)、海拔(zIndices)等子系统,围绕子系统构建 Design Tokens 体系,并将 Design Token 深度融合到基础样式层方案中,使得基础 Design Token 发生变化的时候整个 UI 系统能够进行整体的变化,从而实现整个系统的主题化过程。

Rexd 的主题化结构

// Rexd 的主题化结构
const theme = {
  // 系统色板
  colors: { primary, secondary, gray, red, green, yellow },
  
  // 系统字号
  fontSizes: { note, body, subtitle, title, subheader, header },
  
  // 系统尺寸
  sizes: {
    s1,
    // ... sx
  },
  
  // 系统间距
  space: { s, m, l, xl, xxl },
  
  // 系统边框
  borders: { none, solid, dashed },
  
  // 系统圆角
  radii: { s, m, l },
  
  // 系统阴影
  shadows: { low, median, high },
  
  // 系统海拔
  zIndices: {},
};

Rexd 主题的消费方式

<AppProvider theme={theme}>
  <Box color="primary.50" border="solid" borderColor="line.border">hello wrold</Box>
</AppProvider>

灵活的多端样式方案

在 Rexd 中,我们设计了一套全新的多端样式方案,用来为组件层提供更加灵活的可变样式能力。传统样式方案大多编写复杂,并且难以有效兼顾样式隔离,动态表达,响应式表达,和 Design Token 传值。基于此,我们选择了 CSS in JS 的方案来提供样式层的隔离性和动态性,并引入 Style Props 和 CSS Variable 的方式来为基础组件层提供更加简单有效的可变样式能力和 Design Token 消费方式。通过这套方案,使得我们可以在 React 中获得一种更加简洁和低成本的样式编写体验。

Style Props 的简单的写法

<Box color="brand.normal" border="solid" borderColor="line.border">
  hello world
</Box>

Style Props 的响应式写法

<Flex wrap="wrap">
  <FlexItem span={{ s: 12, m: 6, l: 4 }}>responsive</FlexItem>
  <FlexItem>item</FlexItem>
  <FlexItem>item</FlexItem>
</Flex>

完整的 Style Props 可以参考:https://alibaba.github.io/rex-design/docs/box

易用的动态表单方案

表单页面在中后台场景,尤其是盒马的营运中后台场景一直是一个占据重要角色,并且需求复杂的页面类型。集团现有主要的表单方案要么实现简单性能较差,要么实现复杂,使用成本高。结合盒马的业务现状,考虑到表单场景的多样化需求,我们建立了一个基于 mobx 的表单方案,提供更简单的上手体验,提供按需渲染能力,轻松应对大表单场景,概念少,学习成本低,尤其在动态表单场景,提供更加轻量级和易于学习和理解的的关联表达能力。

const model2 = new FormModel({ prov: '浙江', cities: ['杭州', '绍兴'] });

function BasicEffect() {
  const prov = model2.getField('prov');
  const cities = model2.getField('cities');

  return (
    <Observer>
      {() => (
        <Form model={model2}>
          <FormItem
            component="singleSelect"
            label="省份(单选)"
            field={prov}
            componentProps={{ dataSource: ALL_CITIES.map((item) => item.prov) }}
          />
          <FormItem
            component="multiSelect"
            label="城市(多选)"
            field={cities}
            componentProps={{
              dataSource: ALL_CITIES.find((item) => item.prov === prov.value).cities,
            }}
          />
          <Form.Effect
            watch={prov}
            effect={() => {
              cities.value = [];
            }}
          />
          <ValuePreview />
        </Form>
      )}
    </Observer>
  );
}

还会有更多

上面介绍的内容只是 Rexd 众多特性中的一小部分,目前我们正在持续打磨 Rexd 产品,一方面服务于盒马的营运场景,另一方面我们会持续推动 Rexd 在 Github 上的社区化运作。这些特性还包括:

  • 为移动设备特别优化的响应式能力和自适应交互
  • 默认支持深色模式(Dark Mode),并支持多色模式嵌套使用
  • 基于代码转换实现的小程序兼容方案(基于 Remax 实现)
  • 灵活便捷的全新弹层方案(https://alibaba.github.io/rex-design/docs/overlay/
  • 性能极为强劲的表格方案(https://alibaba.github.io/rex-design/docs/pro-table/
  • 核心组件的可访问性支持
  • 更加现代化的布局能力支持(Grid Layout)
  • 更加友好的手势操作支持

期待

我们的目标是面向社区将 Rexd 打造为更加灵活可用的多端设计体系,在设计侧建立更加灵活可用的设计规则配置能力和配套的设计工具,在技术侧提供更加可用健壮的基础组件体系,为有多端开发需求的中后台业务场景提供低成本的移动化能力。通过将项目开源到 Github,我们也希望更多的得到社区的反馈,帮助我们建设更加灵活,易用,移动端友好的能力。

最后感谢 Rexd 团队的各位同学,他们是 夜沉、飞超、云思、景庄,以及设计师同学 区刀、肖菡、吴姗、吴慧等等。

image.png

f441bb4cf20944bda66ddae869a2c488.png

相关文章
|
3天前
|
移动开发 Android开发 开发者
移动应用与系统:探索移动开发与操作系统的协同进化###
本文深入探讨了移动应用开发与移动操作系统之间错综复杂的关系,揭示了技术进步如何推动用户体验的飞跃。通过案例分析和技术解析,本文阐述了开发者在适应不断变化的操作系统环境中面临的挑战与机遇,以及这种互动如何塑造了我们的数字生活。 ###
|
12天前
|
人工智能 Linux Android开发
移动应用与系统:探索移动应用开发和操作系统的奥秘
【10月更文挑战第5天】 这篇文章将深入探讨移动应用与系统的关键技术,包括移动应用开发的基本流程、工具和技术,以及移动操作系统的核心原理和架构。我们将从浅入深,逐步揭开移动应用与系统的神秘面纱,帮助读者更好地理解和掌握这一领域的知识。
28 2
|
9天前
|
安全 Android开发 UED
移动应用与系统:探索移动应用开发和操作系统的融合
【10月更文挑战第8天】 本文深入探讨了移动应用开发和操作系统之间的紧密联系,分析了它们如何共同塑造用户体验。我们将从技术角度出发,揭示移动应用开发的最佳实践,并讨论移动操作系统的关键特性。通过案例研究,我们展示了如何利用这些技术来创建高效、用户友好的移动应用。
20 2
|
19天前
|
存储 API 数据安全/隐私保护
移动应用与系统:探索移动应用开发与操作系统的奥秘
本文将深入探讨移动应用开发与移动操作系统的关系,分析它们如何相互影响并塑造我们的数字世界。我们将从移动应用开发的基本概念入手,逐步解析移动操作系统的核心功能,以及这两者如何共同推动移动技术的进步。通过深入浅出的方式,让读者对移动应用与系统有一个全面而清晰的认识。
|
17天前
|
开发框架 人工智能 物联网
移动应用与系统:探索移动应用开发与操作系统的融合之道
本文旨在深入探讨移动应用开发与移动操作系统之间的紧密联系,分析它们如何相互影响、共同推动移动互联网的发展。通过阐述移动应用开发的关键技术、主流移动操作系统的特点以及两者在实际应用中的融合案例,本文揭示了移动应用与系统之间的共生关系,并展望了未来发展趋势。
|
18天前
|
存储 Java C语言
MacOS环境-手写操作系统-08-C语言调色板(绘制系统界面)
本文介绍了如何使用C语言在系统界面中应用调色板,通过向硬件发送指令改变颜色显示模式。首先,定义了16种基本颜色并存储在数组中,然后通过关闭中断、写入调色板号和RGB颜色值来更新调色板。接着,展示了如何编译和反汇编C代码,最后通过汇编语言将调色板数据发送给硬件,并实现在屏幕上绘制方块。整个过程涉及到中断处理、端口操作和图形绘制技术。 摘要由CSDN通过智能技术生成
21 3
|
18天前
|
Ubuntu Java C语言
MacOS环境-手写操作系统-07-C语言绘制系统界面
MacOS环境-手写操作系统-07-C语言绘制系统界面
15 1
|
7天前
|
安全 Java Android开发
移动应用与系统:探索移动应用开发与操作系统的奥秘
【10月更文挑战第10天】 本文将深入探讨移动应用开发和操作系统的相关话题,从技术层面揭示其内在联系和相互影响。我们将介绍移动应用开发的基本概念、工具和技术,并详细讲解移动操作系统的核心原理和架构。通过分析实际案例,我们将展示移动应用与操作系统如何共同塑造用户体验和推动技术创新。无论您是开发者还是普通用户,这篇文章都将为您提供宝贵的见解和启发。
14 0
|
18天前
|
Java iOS开发 MacOS
MacOS环境-手写操作系统-10-绘制系统鼠标
MacOS环境-手写操作系统-10-绘制系统鼠标
22 0
|
18天前
|
Java iOS开发 MacOS
MacOS环境-手写操作系统-09-绘制系统字体
MacOS环境-手写操作系统-09-绘制系统字体
31 0