Skip to content
doly mood edited this page Nov 3, 2017 · 2 revisions

cube-ui 是滴滴出行 WebApp 架构组开发的一套基于 Vue.js 2.0 的移动端组件库,目标是让移动端的开发更加容易,让开发人员更加专注于业务逻辑的开发,提升研发效率。

特性

  • 质量可靠

    由滴滴内部组件库精简提炼而来,经历了业务一年多的考验,并且每个组件都有充分单元测试,为后续集成提供保障。

  • 体验极致

    以迅速响应、动画流畅、接近原生为目标,在交互体验方面追求极致。

  • 标准规范

    遵循统一的设计交互标准,高度还原设计效果;接口标准化,统一规范使用方式,开发更加简单高效。

  • 扩展性强

    支持按需引入和后编译,轻量灵活;扩展性强,可以方便地基于现有组件实现二次开发。

优势

相对于同类型的移动端组件库,cube-ui 有哪些优势?

  • 追求极致的体验

    例如,cube-ui 的 Picker 是目前所有移动端组件库中实现最细致,体验也是最好的,接近原生 iOS 选择器的效果。类似的还有 IndexList 索引列表组件,我们在一些交互的细节上都考虑的非常细致,比如对吸顶标题的处理,按压态的处理等。

  • 后编译技术

    后编译技术是滴滴前端团队在“一个项目中引用多个 ES6 开发的模块,由于 Babel 编译会产生多份额外代码”的问题的思考并总结出的一套优化的技术方案。cube-ui 组件库也用到了该技术方案,它会让最终使用方引用 cube-ui 组件库编译产生的代码体积减少,在一定程度上优化了性能。

组件

cube-ui 组件主要包括 3 个部分,基础组件、弹出层组件和滚动组件。目前总共开源了 14 个组件,我们的原则是只开源通用性强的组件。虽然目前组件的个数不多,但是在组件的体验和交互,包括易用性上我们都追求极致。

使用

cube-ui 支持 2 种使用方式,声明式API 式

<template>
  <cube-button @click="showToast">show toast</cube-button>
</template>

<script>
  export default {
    data() {
      return {
        toastTxt: 'toast content'
      }
    },
    methods: {
      showToast() {
        this.$createToast({
          txt: this.toastTxt
        }).show()
      }
    }
  }
</script>

如上代码所示,这里面实际上使用了 2 个 cube-ui 的组件,cube-buttoncube-toast。可以看到,cube-button 我们是用了声明式的创建,而 cube-toast 是通过实例上的 $createToast API 调用。

Vue.js 是比较推崇声明式的方式使用组件,但是考虑到组件嵌套较深的场景,子组件的样式可能被父级样式影响,所以我们针对弹出层类型的组件设计了 API 方式的调用,它们最终会挂载到 body 元素下,避免了样式受父级影响。

扩展

cube-ui 的某些组件有着很好的扩展性,我们可以根据实际场景需求做功能的扩展,举例说明:

  • Popup

    弹层类组件的基类,内置所有的弹层类组件(Toast、Picker、TimePicker、Dialog、ActionSheet )等都是基于 Popup 组件实现,当然我们也可以基于它开发更丰富的弹层类组件。

  • Picker

    移动端选择器组件, TimePicker 就是在 Picker 基础上封装出来的组件,当然我们也可以基于 Picker 扩展出一个城市选择器组件。

演示

演示地址,推荐在手机上浏览。

扫码体验:

cube-ui example

架构设计

cube-ui 底层依赖了 Vuebetter-scroll,并依赖了一系列工具做了构建部署、单元测试等工作;在这些基础上,cube-ui 实现了一系列的组件,如图所示:

enter image description here

Clone this wiki locally