LowCode + 团队组件设计规范 = 灵光一闪 ?

简介: LowCode + 团队组件设计规范 = 灵光一闪 ?

故事从何而起


注意:本文为寒草🌿的自我尝试,部分思想还是很稚嫩。大佬勿喷,不妨多多指教,一起交流~


大家好,我是小寒草🌿呀!


为什么是小寒草呢⚡️,因为我最近发现自己很渺小,真就是寄蜉蝣于天地,渺沧海之一粟。哀吾生之须臾,羡长江之无穷...


打住,我也不往远了扯,直接说事情的起源。在去年的年中,我的上一任荣誉小组长为我分享了他的组件拆分与设计经验,我也从他的身上学到了很多☀️


前几天在和一个实习生同学一起开发项目,我就借鉴了前荣誉小组长的经验,做了比较充分的前期设计工作。但是其实在开发完成后的 review 的过程中还是发现会存在一定程度的差异。


最开始我的组件设计把组件分成了四类:


网络异常,图片无法展示
|


这里的划分方案单纯的从我的经验出发,略显稚嫩。


  • page 组件:一般不复用,即页面对应的组件,我眼里它相当于主板把各个组件和样式组合为一整个页面
  • Layout 组件:纯样式复用,不包含业务
  • 业务基础组件:参考 element-ui 等基础组件库,此类组件一般叫做 xxx-formxxx-table,暴露的 api 也会基本与基础组件一致
  • 基础业务组件:常见的业务基本都是由增删改查组成的,此类的组件也是对这一粒度业务的封装。此类组件一般叫做:xxx-creatorxxx-deleterxxx-updaterxxx-viewer


之后我本次的例子也是来自于业务基础组件:


component TicketForm [
工单信息表单
ticket-form
--props--
disabled { Boolean }
disabledFields { Array<String> }
--events--
--methods--
getData() => TicketData;
setData(ticketData: TicketData) => Undefined;
clearData() => Undefined;
validate() => Promise.<Boolean>;
clearValidate() => Undefined;
--slots--
]


网络异常,图片无法展示
|


正如大家所见,我明确规定了一个业务基础组件 ticket-form 提供的 api 及所需的 props


props:


  • disabled
  • disabledFileds


methods:


  • getData
  • setData
  • clearData
  • validate
  • clearValidate


之后就进入了开发阶段,但是在我进行 code review 的时候发现了 api 实现不完整的情况。起初我的强迫症犯了,但是后来我想了又想不等单纯的通过 review 去约束,这样成本极高,而且一致的组件其实并不具备很高的 review 价值。


我就去思考解决这个问题的办法,之后经过我大概五分钟的思考,就有了后面的故事。


故事又将如何延续


网络异常,图片无法展示
|


由于我的强迫症,我迫切的想要去解决这个问题,而这个问题其实被我定义为:


提供自动化方案,解决通用组件实现不一致的问题


首先,需要确定我们现阶段有什么:


  • 公司内部基础组件库(各位参考 elementui)
  • 系统内已实现的业务组件
  • 我和前任小组长敲定下的组件设计规范(且不论这个规范是否优秀)


于是我画了这样一张图


网络异常,图片无法展示
|


下面我来对这个图进行一些解读:

  1. 首先我们通过团队的开发经验输出了一定的规范或者约束
  2. 之后,基于基础组件库或者业务组件库我们会产出一定的最佳实践或者 demo 案例
  3. 在之后经过一定阶段的博弈,大家对规范形成了一定的共识
  4. 对于我和前任小组长,我们形成了基础业务组件和业务基础组件的分类并将其 API 统一化
  5. 最终,基础组件足够统一话后我们就可以采用 low code 的方式进行输出


没错,最后我的想法就是用 low code 解决。大家可能会质疑这个代码怎么可能如此一致,但是就像上一章中 form 的案例,其实按照这种约束,代码还是及其统一的。

之后我花了一个小时,简单的做了一个生成 xxx-form 组件的 demo,其中生成代码的方法如下:


export const getFormCode = (schema) => {
  return `<template>
  <q-form
    ref="form"
    :model="formData"
    :rules="rules"
    :disabled="disabled"
  >
    ${
      schema.map(item => `
      <q-form-item label="${item.label}" prop="${item.key}" ${item.isInline?'class="inline-form-item"':''}>
        <q-input v-model="formData.${item.key}" :placeholder="请输入${item.label}" :disabled="disabledFields.includes('${item.key}')" />
      </q-form-item>
      `).join('\n')
    }
  </q-form>                                   
  </template>
  <script>
  const getBaseCustomFormData = () => ({
    ${
      schema.map(item => `
        ${item.key}: ''
      `).join(',\n')
    }
  })
  export default {
  props: {
    disabled: {
      type: Boolean,
      default: false
    },
    // Array.<String>
    disabledFields: {
      type: Array,
      default: () => []
    }
  },
  data() {
    return {
      formData: getBaseCustomFormData(),
      rules: {
        ${
          schema.filter(item => item.required).map(item => `
            ${item.key}: [
              { required: true, message: '请输入${item.label}', trigger: 'blur' }
            ]
          `).join(',\n')
        }
      },
    };
  },
  methods: {
    setData(data) {
      this.formData = Object.assign(getBaseCustomFormData(), data);
    },
    getData() {
      return Object.assign({}, this.formData);
    },
    clearData() {
      this.formData = getBaseCustomFormData();
    },
    validate() {
      return this.$refs.form.validate();
    },
    clearValidate () {
      this.$refs.form.clearValidate();
    },
  }
  };
  </script>
  <style lang="scss" scoped>
  .inline-form-item {
    display: inline-block;
    width: 50%;
    vertical-align: top;
  }
  </style>
  `
}


效果也比较简单,支持我们常用的布局配置:


网络异常,图片无法展示
|


最后生成的代码也一定是符合我对于 xxx-form 组件的规范的。


之后我拿着这个 demo 和我的前任小组长聊天,之后又在下班路上和大领导聊了聊组件设计和团队规范。


于是就有了最后一章的总结 ✨


最后一章留给总结


网络异常,图片无法展示
|


这只是一个简单的 demo,主要是和大家分享我在开发中的灵感一现,但是现在来看其实是有问题的:


  • 关于组件分类与设计的合理性
  • 关于这个代码生成程序的局限性
  • ...


其实如果想做一个东西,应该有更多的准备,站在一个更大的视野去挖掘价值。本文思想比较稚嫩,也请多多指教。

相关文章
|
编解码 监控 网络协议
一文读懂以太网与CANoe的配置
一文读懂以太网与CANoe的配置
一文读懂以太网与CANoe的配置
|
开发工具 git
Git从远程仓库拉取指定的分支
Git从远程仓库拉取指定的分支
3433 0
|
人工智能 数据管理 API
手把手教你搭建企业微信AI助手
全程图文,一步一步带你搭建基于云百炼的RAG应用,并配置知识库,让AI助手更专业、更智能。
2570 1
|
测试技术 持续交付 开发工具
《对于大规模的代码项目,如何进行有效的代码管理》
有效管理大规模代码项目至关重要。使用Git等版本控制系统追踪变化;合理组织代码结构;制定统一代码风格;编写详细文档与注释;实施持续集成和自动化测试;执行代码审查;持续优化代码;支持并行开发;强化团队协作;定期备份代码。这些措施能显著提升代码质量和可维护性。
277 11
|
缓存 前端开发 API
俯瞰 Monorepo,别一番风景!
本故事简要地介绍了 Monorepo 的 What 和 Why,重点篇幅在于搭建一个好用的 Monorepo 工程时应该考虑的点。可以作为你在选择工具时的条件,也可以作为你在搭建 Monorepo 工程时查漏补缺的参考。希望这对你有所帮助,哪怕只是一点点 \^O^
113 2
俯瞰 Monorepo,别一番风景!
|
安全 Linux 网络安全
龙蜥Anolis OS:国产操作系统的逆袭之路,它将如何引领中国IT业翻天覆地的变化?揭秘未来数字世界的心脏!
【9月更文挑战第4天】在信息化时代,操作系统作为计算机系统的核心,连接着上层软件与底层硬件。随着全球化及地缘政治的影响,国产操作系统愈发重要。龙蜥Anolis OS作为佼佼者,基于Linux内核,兼具开源、灵活与安全特性,针对国内用户优化,支持多种编码标准和汉字输入法,提升中文用户体验。其采用角色访问控制、SELinux等技术,保障系统安全。Anolis OS还拥有活跃的开源社区,促进功能完善与创新。随着国家政策扶持和产业链协同,Anolis OS正引领国产操作系统迈向更广阔的应用领域,推动软硬件生态系统的成熟,成为全球多元化计算生态的重要组成部分。
610 1
|
存储 算法 安全
深入解析RSA算法原理及其安全性机制
深入解析RSA算法原理及其安全性机制
|
前端开发 程序员 开发者
光辉璀璨:开发者的壮丽"高光时刻"
作为开发者,在自己的开发生涯中,肯定都会经历一些让自己激动和自豪的"高光时刻",这些时刻是我们在技术道路上的重要里程碑,带给我们成就感和动力。就拿我自己的程序开发生涯来讲,截止目前,我的开发经历可以用一个曲线来表示,为什么这么说?原因就是自己的开放经历一直都是叠嶂起伏,忽高忽低,忽低忽高,反反复复的演绎。本文就来简单分享一下我自己的“高光时刻”。
169 9
光辉璀璨:开发者的壮丽"高光时刻"
|
前端开发 JavaScript Java
阿里、腾讯、百度大厂的程序员编程指南规范
整理了几个大厂的编程规范,语言包含:**Javascript、Css、Java、C#**,这些文档不仅是初学者有必要看,有经验的程序员也是可以学习的,编程规范不仅是规则,更是可以从大厂的规范中学习到很多知识,比如大厂为什么这么订规范、他们是考虑原则是什么,带着类似问题的思考,都有非常有利于我们提高编程能力的。
2835 0
阿里、腾讯、百度大厂的程序员编程指南规范