天天看点

盒马跨端设计系统 ReX Design For OS面向多端设计,而不是单一设备一套代码,多端可用轻量的主题化逻辑灵活的多端样式方案易用的动态表单方案还会有更多期待

来源:Alibaba F2E公众号

作者:景庄

6 个月前,在 D2 前端技术论上我们向社区分享了

《盒马中后台跨端方案》

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

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

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

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

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

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

盒马跨端设计系统 ReX Design For OS面向多端设计,而不是单一设备一套代码,多端可用轻量的主题化逻辑灵活的多端样式方案易用的动态表单方案还会有更多期待

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

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

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

盒马跨端设计系统 ReX Design For OS面向多端设计,而不是单一设备一套代码,多端可用轻量的主题化逻辑灵活的多端样式方案易用的动态表单方案还会有更多期待

详细内容可以参考:

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>
  );
}           

更详细的文档可以参考:

https://alibaba.github.io/rex-design/docs/xform/usage

还会有更多

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

期待

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

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

盒马跨端设计系统 ReX Design For OS面向多端设计,而不是单一设备一套代码,多端可用轻量的主题化逻辑灵活的多端样式方案易用的动态表单方案还会有更多期待
盒马跨端设计系统 ReX Design For OS面向多端设计,而不是单一设备一套代码,多端可用轻量的主题化逻辑灵活的多端样式方案易用的动态表单方案还会有更多期待

继续阅读