高度可定制化业务系统架构探索

广告位招租
扫码页面底部二维码联系

ToB类产品有非常丰富的需求变更,而大多【转载请注明来源】本文版权归作者所有,未经授权不得转载。数多样化的需求背后,反应到系统层面都是业【作者:唐霜】【本文受版权保护】务核心实体的变更,因此,一套可定制化的业【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】务系统对于这类场景而言非常有帮助,不仅可【本文受版权保护】本文作者:唐霜,转载请注明出处。以大大缩短研发过程,同时更有利于整个系统转载请注明出处:www.tangshuang.net【版权所有,侵权必究】的扩展。本文将探索此类可定制化业务系统的【作者:唐霜】【作者:唐霜】架构,试图找到一些共性,提供一种架构思路本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】

未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。

背景

我在长期的工作中,需要不断的面对业务的变【本文首发于唐霜的博客】原创内容,盗版必究。更所带来的各种细碎的需求。其中很多需求只原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】是改动一些细节,但是,从研发层面,却要经本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】历需求评审->开发->测试-【本文受版权保护】原创内容,盗版必究。>发布等一系列过程,而在我看来,这【转载请注明来源】【本文首发于唐霜的博客】些处理费时费力,非常浪费。有没有一种可能转载请注明出处:www.tangshuang.net【未经授权禁止转载】,类似这样的变更,不需要更改代码,只需要【关注微信公众号:wwwtangshuangnet】【未经授权禁止转载】通过在线的配置变更,就可以完成细节功能的【未经授权禁止转载】【未经授权禁止转载】变更呢?

【作者:唐霜】本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】

其实,这一想法也正是需求方在想的,他们也【转载请注明来源】本文作者:唐霜,转载请注明出处。希望系统能够根据需求主动进行配置,而无需本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。每次都需要进行漫长的研发流程。对于需求方【版权所有,侵权必究】转载请注明出处:www.tangshuang.net来说,迭代发版太漫长了,有时候根本等不到转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。发版周期就想要上某一个更改。同时,有时候本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。,研发同学实现的需求还不一定准确,如果能著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。将一些可定制的能力交给需求方自己去定制,本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】那么实现的也更准确。

本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshua【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。ng.net转载请注明出处:www.tangshua【作者:唐霜】原创内容,盗版必究。ng.net原创内容,盗版必究。

于是,我们开始了业务系统可定制化的探索。

本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshua【关注微信公众号:wwwtangshuangnet】【本文受版权保护】ngnet】

可定制化业务系统与低代码平台的区别

看上去,上面所表述的可定制化与低代码平台原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】的效果非常像,都是可以让非开发人员可以主本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。动参与到产品的创建过程中。然而,它们存在未经授权,禁止复制转载。【转载请注明来源】着本质的区别。

【原创不易,请尊重版权】原创内容,盗版必究。【作者:唐霜】
  • 产物不同:低代码平台的产物是具体的界面,【原创内容,转载请注明出处】【原创内容,转载请注明出处】同时包含了用于存储数据的数据结构;可定制转载请注明出处:www.tangshuang.net【版权所有,侵权必究】化的产物是具体的元数据,对于应用来说,是【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。用这些元数据去实现效果
  • 本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。
  • 素材不同:低代码平台的素材是有平台提供的【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。组件,而可定制化围绕业务,需要的组件得根【版权所有,侵权必究】原创内容,盗版必究。据业务需求进行定制
  • 转载请注明出处:www.tangshua【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】ng.net原创内容,盗版必究。
  • 资源不同:低代码平台的用户不需要自己设计【作者:唐霜】本文版权归作者所有,未经授权不得转载。数据库,只把平台产品当作设计工具使用;可【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。定制化是在原有数据库的基础上进行扩展定制未经授权,禁止复制转载。原创内容,盗版必究。,其数据库结构虽有改动,但大部分还是继承【本文首发于唐霜的博客】【未经授权禁止转载】业务本身的特性
  • 著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。
  • 侵入程度不同:低代码平台要求你把整个功能未经授权,禁止复制转载。【本文首发于唐霜的博客】托管在平台上,从底层到应用都是由平台提供原创内容,盗版必究。【作者:唐霜】;可定制化则在原来的系统基础上改造,或者未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。作为系统的一部分参与完成整个业务
  • 未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】【版权所有,侵权必究】

总而言之,低代码平台是相对而言独立的完整【作者:唐霜】【原创不易,请尊重版权】的设计工具,而可定制化是在原有系统上提供【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。可扩展的灵活的元数据编辑能力。

本文作者:唐霜,转载请注明出处。【本文受版权保护】原创内容,盗版必究。【版权所有,侵权必究】

可定制化业务系统的设计

我们需要去思考,一个业务系统中,在什么情转载请注明出处:www.tangshuang.net【转载请注明来源】况下,我们使用可定制化的方案比传统固定死未经授权,禁止复制转载。原创内容,盗版必究。的方案更能带来价值和效益。我个人认为,主著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net要有以下这些情况:

【转载请注明来源】著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】转载请注明出处:www.tangshua【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.netng.net
  • 字段的格式化、多语言等展示信息
  • 【本文受版权保护】未经授权,禁止复制转载。【作者:唐霜】【未经授权禁止转载】
  • 字段的计算规则/公式
  • 【访问 www.tangshuang.n未经授权,禁止复制转载。转载请注明出处:www.tangshuang.netet 获取更多精彩内容】【未经授权禁止转载】转载请注明出处:www.tangshua著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。ng.net
  • 表单中字段的各种逻辑,例如必填、隐藏、校未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。验逻辑等等
  • 【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshu【原创内容,转载请注明出处】【本文受版权保护】ang.net【作者:唐霜】
  • 业务的流程,每一个节点的逻辑
  • 【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。
  • 详情页的展示顺序
  • 本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshua【本文首发于唐霜的博客】【原创内容,转载请注明出处】ngnet】
  • 列表页根据配置展示需要的字段、顺序、筛选【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。功能等
  • 【访问 www.tangshuang.n原创内容,盗版必究。【版权所有,侵权必究】et 获取更多精彩内容】【版权所有】唐霜 www.tangshu【转载请注明来源】【版权所有】唐霜 www.tangshuang.netang.net著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。

基于上面这些思考,我认为定制化的内容主要【本文受版权保护】未经授权,禁止复制转载。包括四方面:字段可定制化、流程可定制化、【版权所有,侵权必究】【版权所有,侵权必究】表单可定制化、界面可定制化。

【原创内容,转载请注明出处】【未经授权禁止转载】未经授权,禁止复制转载。【转载请注明来源】

字段可定制化

字段可定制是实现灵活化的第一步,看上去挺转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】简单的,不就是可以去配置嘛。但是,当我们【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshuang.net真正去分析的时候,发现,并没有想象的那么著作权归作者所有,禁止商业用途转载。【作者:唐霜】简单。

本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshua【原创内容,转载请注明出处】【原创内容,转载请注明出处】ngnet】【原创不易,请尊重版权】转载请注明出处:www.tangshua【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】ng.net

分析

我们需要去思考,什么样的字段是可以定制化【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】的。在业务系统中,有些字段具有特殊逻辑,原创内容,盗版必究。本文作者:唐霜,转载请注明出处。在业务中,是不可更改的,而有些字段则仅仅【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】是为了记录一个数据,可随意更改。因此,我【版权所有,侵权必究】【转载请注明来源】们可以把字段分为3类:

未经授权,禁止复制转载。【原创内容,转载请注明出处】

来自知乎专栏

【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshu转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】ang.net本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshua未经授权,禁止复制转载。转载请注明出处:www.tangshuang.netng.net
【转载请注明来源】原创内容,盗版必究。

固定字段,预设字段,自定义字段

【本文首发于唐霜的博客】未经授权,禁止复制转载。
著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshu本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。ang.net【关注微信公众号:wwwtangshua【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。ngnet】

字段管理界面

【作者:唐霜】未经授权,禁止复制转载。【版权所有,侵权必究】未经授权,禁止复制转载。
未经授权,禁止复制转载。原创内容,盗版必究。【本文首发于唐霜的博客】【关注微信公众号:wwwtangshua【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】ngnet】

字段可定制的本质,实质上是让我们可以主动【本文受版权保护】本文版权归作者所有,未经授权不得转载。去定制业务对象(上图中的“维度”)。业务【原创内容,转载请注明出处】【未经授权禁止转载】对象及当前业务事件发生的主体,及其参与者【本文受版权保护】转载请注明出处:www.tangshuang.net。和低代码那种从零开始自己搭建不同,我们著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】定制业务对象,一般可以通过脚本把一些基础【本文首发于唐霜的博客】【版权所有】唐霜 www.tangshuang.net的固定的内容先倒入到数据库中,即初始化阶【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。段。只有到后期需要进行细节变更的时候,管【原创不易,请尊重版权】【原创内容,转载请注明出处】理员可到后台主动变更字段属性。

著作权归作者所有,禁止商业用途转载。【本文受版权保护】【关注微信公众号:wwwtangshua【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。ngnet】

这种强烈的业务属性还会带来另外一种情况,本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。即如果一个业务中存在一个字段,那么必然存【未经授权禁止转载】【原创不易,请尊重版权】在另外一个字段。这两个字段可能是一因一果【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】,也可能是合因一果中的因子,总之,当一个【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。字段出现的时候,意味着另外一个字段必须在【原创不易,请尊重版权】【作者:唐霜】当前这个业务对象中。

【版权所有】唐霜 www.tangshu【版权所有】唐霜 www.tangshuang.net【转载请注明来源】ang.net【版权所有,侵权必究】【本文首发于唐霜的博客】

添加自定义字段

【原创内容,转载请注明出处】【作者:唐霜】著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。
【作者:唐霜】转载请注明出处:www.tangshua未经授权,禁止复制转载。原创内容,盗版必究。ng.net【作者:唐霜】原创内容,盗版必究。

编辑字段(展开全部状态下)

未经授权,禁止复制转载。【转载请注明来源】本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。
转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。【本文受版权保护】ng.net著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。

无论是添加,还是编辑字段,都是对字段属性【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】的编辑。字段属性是用以描述这个字段的元数【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。据,可以和字段值剖离,也可以和字段值相互【作者:唐霜】原创内容,盗版必究。影响(例如通过元数据决定字段的值如何计算本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】得到)。因此,实际上,字段的定制化的核心【未经授权禁止转载】【本文首发于唐霜的博客】,是提供可覆盖业务需求的字段属性的定制化【作者:唐霜】未经授权,禁止复制转载。。怎么才能覆盖业务需求呢?我们慢慢分析。

转载请注明出处:www.tangshua【版权所有】唐霜 www.tangshuang.net【转载请注明来源】ng.net【关注微信公众号:wwwtangshua【版权所有,侵权必究】未经授权,禁止复制转载。ngnet】本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】

首先,和字段一样,属性也分3种:固定属性【转载请注明来源】著作权归作者所有,禁止商业用途转载。、预设属性、自定义属性。它们在行为上和字原创内容,盗版必究。【原创不易,请尊重版权】段的种类的行为相似。

【作者:唐霜】未经授权,禁止复制转载。转载请注明出处:www.tangshua【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】ng.net

固定属性、预设属性、自定义属性

本文作者:唐霜,转载请注明出处。原创内容,盗版必究。【版权所有】唐霜 www.tangshu【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】ang.net
本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshua本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。ngnet】【版权所有】唐霜 www.tangshu原创内容,盗版必究。转载请注明出处:www.tangshuang.netang.net

固定属性必须被设定值。预设属性可以留空不【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net设置值,并且在默认状态下收缩起来,点击上【版权所有,侵权必究】【本文首发于唐霜的博客】图中的“显示所有选项”时在展示出来用于设著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】置。自定义属性默认情况下(第一次创建时)原创内容,盗版必究。【作者:唐霜】不存在,需要手动添加属性用于设置。

【版权所有】唐霜 www.tangshu【版权所有,侵权必究】【未经授权禁止转载】ang.net【原创内容,转载请注明出处】【作者:唐霜】

在一些场景下,某些属性是被绑定在一起的。

【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。

转载请注明出处:www.tangshua【原创内容,转载请注明出处】【转载请注明来源】ng.net【本文受版权保护】

上图中,当“数据类型”被选中为数字时,“著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】格式”属性被立马展示出来,它们本质上是两本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。个属性,类型是一个属性,格式是一个属性,【未经授权禁止转载】【作者:唐霜】只是它们强关联而已。并且不同的数据类型,【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】其格式的配置完全不同。例如日期需要配置日本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】期/时间格式等。

著作权归作者所有,禁止商业用途转载。【本文受版权保护】【转载请注明来源】

属性可以分为3个大类:

著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。
分类 定义 举例
业务性质 描述和业务本身的定义,业务逻辑相关的属性 字段类型、校验器
交互性质 描述在界面上用于控制该字段的展示逻辑或交互逻辑的属性 字段在表单中是否需要展示(在什么情况下需要展示)
技术性质 描述在数据提交时(前后端交互时)数据应该以什么方式提交到后端接口 名为gp_name的字段实际上对应后端接口的gp.gp_name,其中gp是一个对象

属性可以分为9个子类:

【原创内容,转载请注明出处】【版权所有,侵权必究】【作者:唐霜】
属性子类 定义 举例
值相关 该属性在前端运行时,使用该属性作为状态 value, compute, getter
校验器相关 在验证该字段值时使用 required, validators
类型相关 控制该字段的数据类型时使用 type
存储相关 导出数据时,该字段以什么形式进行转化 save, create
提交相关 提交数据到后端接口时,该字段要怎么处理 map, flat
逻辑相关 当前字段在当前环境下是否形成了某种状态 required, readonly, hidden
监听相关 当前字段的值发生变化时被调用 watch, catch
衍生资源相关 当前字段依赖另外一个字段,那么在对象中就必须同时存在这两个字段,否则就会出错 deps
自定义 其他自己自定义的属性

这些类型在具体设计时不一定都会用得到,即本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net使在同一系统中,不同字段可能也各不相同。

【访问 www.tangshuang.n著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.netet 获取更多精彩内容】【未经授权禁止转载】

相同的属性,在被不同字段使用时,也有权限原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】的区别,例如在字段A中readonly这【转载请注明来源】【原创内容,转载请注明出处】个字段是可以被定制化的,但是在字段B中r未经授权,禁止复制转载。原创内容,盗版必究。eadonly这个属性是规定死的。这需要【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。我们在设计时,让我们的系统可以灵活的保持【关注微信公众号:wwwtangshuangnet】【转载请注明来源】这种权限关系。

原创内容,盗版必究。【未经授权禁止转载】【作者:唐霜】

属性值必须是支持动态计算的,例如requ【本文首发于唐霜的博客】【本文受版权保护】ired属性可能由对象的另外一个字段的值本文版权归作者所有,未经授权不得转载。【作者:唐霜】来决定,此时的required在进行定制原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】时,一定时一个表达式,而非固定死的值。在【作者:唐霜】【作者:唐霜】很多定制场景下,甚至设计者不会想到还有这【原创不易,请尊重版权】【本文首发于唐霜的博客】个设计,因为他们没有接触过同一字段的同一本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net属性在不同情况下内容不同。

【版权所有】唐霜 www.tangshu【版权所有,侵权必究】【本文首发于唐霜的博客】ang.net【作者:唐霜】

属性值需要在不同的条件下动态的给出结果。

未经授权,禁止复制转载。【版权所有】唐霜 www.tangshu【版权所有,侵权必究】【作者:唐霜】ang.net【访问 www.tangshuang.n本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netet 获取更多精彩内容】

【本文首发于唐霜的博客】转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。ng.net

上图中,“提示语”这个属性需要去“报价单本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net”这个维度中找,查找的条件可以自己配置,本文作者:唐霜,转载请注明出处。【未经授权禁止转载】找到的是多个报价单对象,取值只取其中一个【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。,且取的是报简单的“报价时间”这个字段的【本文受版权保护】原创内容,盗版必究。值,取值条件是取(筛选结果中的)“最大值【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。”。

本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。

动态取属性值的设计意味着你不能在设计时把【未经授权禁止转载】原创内容,盗版必究。属性值直接当作一个固定值对待而设计死,你【访问 www.tangshuang.net 获取更多精彩内容】【版权所有,侵权必究】需要创建一套表达式规则,通过表达式来动态原创内容,盗版必究。【本文首发于唐霜的博客】读取需要的值。

【作者:唐霜】【转载请注明来源】

提到这里,字段的值也可以是动态的,我们称【原创内容,转载请注明出处】【作者:唐霜】为“关联类型”。例如,“订单”的“商品”转载请注明出处:www.tangshuang.net原创内容,盗版必究。字段实际上是关联“商品”对象的ID,而且【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】它们之间的关系是1:n(一对多)关系。这【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】个设计需要在数据类型这个固定属性处实现。

【版权所有,侵权必究】【访问 www.tangshuang.n【转载请注明来源】【本文受版权保护】et 获取更多精彩内容】转载请注明出处:www.tangshua【本文首发于唐霜的博客】【未经授权禁止转载】ng.net【本文受版权保护】

最后一种情况是,在我们的产品中,同一个属本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。性,可能在不同情况下,需要采用不同的值。【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net例如,“消费额”这个字段的“格式”属性,原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net在个人详情页需要使用“$10,000,0【未经授权禁止转载】【作者:唐霜】00.00”这种格式,而在记录页面为了省著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。空间又需要使用“$10mn”这种缩略形式本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】。这也就意味着,同一个字段,其属性有多套未经授权,禁止复制转载。原创内容,盗版必究。方案。这该怎么设计呢?

本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】【未经授权禁止转载】

多方案属性设计

未经授权,禁止复制转载。转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。【未经授权禁止转载】ng.net
【版权所有,侵权必究】【版权所有,侵权必究】

也就说,同一个字段的同一属性,在不同情况原创内容,盗版必究。【未经授权禁止转载】下还有的选择。不过,是否启用方案应该是可【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】选的,如果某些属性没必要启用方案,那么就【原创内容,转载请注明出处】原创内容,盗版必究。没必要勉强去设定多套方案。

原创内容,盗版必究。【本文受版权保护】本文作者:唐霜,转载请注明出处。【转载请注明来源】

表设计

为了支撑上面的分析中提到的这些点,我们必【版权所有】唐霜 www.tangshuang.net【转载请注明来源】须在设计时尽可能的让表可以灵活扩展。

【作者:唐霜】【本文受版权保护】原创内容,盗版必究。

字段定制化表结构设计

【未经授权禁止转载】【作者:唐霜】本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】
【关注微信公众号:wwwtangshua【本文受版权保护】本文作者:唐霜,转载请注明出处。ngnet】【本文首发于唐霜的博客】

这些表与实际的业务表分开,与业务表没有本【本文受版权保护】【本文受版权保护】质上的关联,如果不使用字段定制化的能力,【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.net这些表可以从业务系统中删除而不影响原有业【原创不易,请尊重版权】【未经授权禁止转载】务数据。

原创内容,盗版必究。【转载请注明来源】【本文首发于唐霜的博客】【原创不易,请尊重版权】

dimensions表即维度表,它的作用转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。是让我们方便的快速找到一个维度都有哪些字【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。段,通过维度表fields字段可以从fi未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。elds表中读取出这些字段。不过需要强调转载请注明出处:www.tangshuang.net【转载请注明来源】的是,dimensions维度表中的一个【转载请注明来源】【转载请注明来源】维度并不等于一个数据库表的引用,一个维度【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】实际上可以囊括多张表中的多个字段。fie【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.netlds中的key建议使用table.co【原创不易,请尊重版权】【版权所有】唐霜 www.tangshuang.netlumn的方式命名,这也就意味着,维度中未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net引用的字段table部分可以不同。

本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】【作者:唐霜】

fields是字段表,它指明了字段可定制著作权归作者所有,禁止商业用途转载。【转载请注明来源】化系统中的字段(key)和原始业务表字段【未经授权禁止转载】【原创内容,转载请注明出处】(table+column)之间的关系。【原创内容,转载请注明出处】原创内容,盗版必究。fields这个表里面的key是原始业务【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。表字段的别称,在字段可定制化系统中使用。本文版权归作者所有,未经授权不得转载。【作者:唐霜】name是字段的展示名。type是字段的本文作者:唐霜,转载请注明出处。【作者:唐霜】数据类型,用以控制原始字段数据类型和实际未经授权,禁止复制转载。【原创内容,转载请注明出处】需要的数据类型不一致时的调度。polic【版权所有】唐霜 www.tangshuang.net【本文受版权保护】y用以表示当前这个字段是固定、预设、自定【未经授权禁止转载】【作者:唐霜】义字段。deps则是前文提到的,一个字段著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。可能必须依赖其他字段,如果定制化系统中d【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。eps里有值,意味着这套字段是绑定在一起【作者:唐霜】【本文首发于唐霜的博客】的。

本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshu【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】ang.net

attributes是整个字段可定制化的【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。核心表,虽然它的字段比较少。一个字段有哪【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】些属性被设置了值,全部在attribut【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。es表中(不包含方案部分),一条attr【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。ibute就是其中一个属性。从上文的图中【版权所有,侵权必究】【本文首发于唐霜的博客】,你可以看到,不同的属性,在进行配置的时【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net候,交互非常不同,可以说是千差万别。

【本文受版权保护】【转载请注明来源】【本文受版权保护】

这时,我们看attribute_conf【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。igs表,这个表是用于打开属性编辑弹窗时【原创内容,转载请注明出处】【访问 www.tangshuang.net 获取更多精彩内容】,展示出来可配置的属性的列表,然后从at【本文首发于唐霜的博客】【版权所有】唐霜 www.tangshuang.nettributes表和schemes表中拉未经授权,禁止复制转载。未经授权,禁止复制转载。取数据进行填充。

本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。

当我们打开属性弹窗时,首先从attrib原创内容,盗版必究。【本文首发于唐霜的博客】ute_configs中读取所有备选属性【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】,其中根据policy进行分类,0:固定【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。属性立即展示在界面上,预设属性1:立即展【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。示在界面上,2:可以通过“更多”展开,3【版权所有,侵权必究】【未经授权禁止转载】:自定义属性不会出现(在添加自定义属性时【本文受版权保护】【本文首发于唐霜的博客】,可通过下拉复用)。type属性决定了当原创内容,盗版必究。【本文受版权保护】前这个属性的基础交互类型,比如字符串、数【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】字、下拉列表等等,这个type是决定属性未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。的交互类型,而非字段的类型,这里需要避免【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。混淆。required代表这个属性必须填本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。写,不能留空(固定属不能留空,因此,可以【版权所有】唐霜 www.tangshuang.net【本文受版权保护】认为required只针对预设属性)。n【版权所有,侵权必究】【访问 www.tangshuang.net 获取更多精彩内容】eeds表示当前这个属性依赖其他属性,如【转载请注明来源】转载请注明出处:www.tangshuang.net果被依赖的属性不存在,会造成错误。com【未经授权禁止转载】【作者:唐霜】ponent这个字段是交互的关键,它是一【本文受版权保护】【关注微信公众号:wwwtangshuangnet】个复杂的结构,里面包含了这个属性在界面上【本文受版权保护】【原创内容,转载请注明出处】的配置,也就是说,当前这个属性在配置界面【本文首发于唐霜的博客】【转载请注明来源】上怎么交互完全由component决定。【未经授权禁止转载】【未经授权禁止转载】同时,component中的内容决定(t【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.netype字段也有影响,因为基础type可能【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】不需要component)了attrib【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】utes表中value字段的值,attr【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。ibutes.value这个字段和sch本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.netemes.value字段也是一个复杂结构本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】(这两个字段结构相同)。为什么是复杂结构著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】呢?因为每一个component输出的结转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net果不同,比如有的输出的是固定的数值,有的【转载请注明来源】本文作者:唐霜,转载请注明出处。输出的是动态表达式,有的输出的是字符串,未经授权,禁止复制转载。【本文首发于唐霜的博客】甚至输出JSON数组,所以,value必【转载请注明来源】未经授权,禁止复制转载。须是一个字符串类型,实质上是一个JSON著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。在数据库中的表达形式。它的结构可以设计为【原创不易,请尊重版权】原创内容,盗版必究。复合json-schema的结构。

原创内容,盗版必究。【关注微信公众号:wwwtangshua本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】ngnet】

scheme_configs归档了有哪些【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】方案可以使用。其中一个需要理解的地方在于【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。attributes字段,它代表当前这个【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。方案仅支持这些属性。在交互上,仅当处于a【本文首发于唐霜的博客】【本文受版权保护】ttributes中的属性被选中时,右侧转载请注明出处:www.tangshuang.net【作者:唐霜】的方案列表中才会出现这个方案。

未经授权,禁止复制转载。【版权所有】唐霜 www.tangshu【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】ang.net转载请注明出处:www.tangshua【版权所有,侵权必究】【未经授权禁止转载】ng.net【版权所有】唐霜 www.tangshu【原创不易,请尊重版权】转载请注明出处:www.tangshuang.netang.net

schemes这个表实际上和attrib【本文首发于唐霜的博客】【原创不易,请尊重版权】utes这个表是平行的,或者你可以认为它转载请注明出处:www.tangshuang.net【作者:唐霜】是attributes表的补充。如果没有本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】“方案”这个东西,那么不需要它,如果需要【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshuang.net“方案”,那么在读取属性值时,需要考虑从著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】对应的方案中读取,如果没有对应方案,就退著作权归作者所有,禁止商业用途转载。【本文受版权保护】回到attributes中的值。为了查询本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。方便,schemes中冗余了name字段转载请注明出处:www.tangshuang.net原创内容,盗版必究。,这样在查的时候就不需要去读scheme本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。_configs表。

【本文受版权保护】【原创内容,转载请注明出处】转载请注明出处:www.tangshua【版权所有,侵权必究】【版权所有,侵权必究】ng.net原创内容,盗版必究。

让我们回到具体的某个业务场景下。现在,我本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。们需要展示公司详情,展示时,需要根据字段本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.net 获取更多精彩内容】定制的结果展示这些信息。此时,我们后端在【未经授权禁止转载】本文作者:唐霜,转载请注明出处。处理时大致流程如下:

【作者:唐霜】【访问 www.tangshuang.n未经授权,禁止复制转载。【本文受版权保护】et 获取更多精彩内容】未经授权,禁止复制转载。

【访问 www.tangshuang.n【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。et 获取更多精彩内容】原创内容,盗版必究。原创内容,盗版必究。【原创不易,请尊重版权】

基于这一设计,我们可以在完全不该动原有业转载请注明出处:www.tangshuang.net【本文受版权保护】务,在原有业务之外再建立一套系统实现可定著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。制化的能力。

【版权所有,侵权必究】【关注微信公众号:wwwtangshua【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。ngnet】【转载请注明来源】

架构设计

要支撑上述设计,我们需要一个可以独立于原【原创不易,请尊重版权】【作者:唐霜】有业务的系统,同时又有一定扩展性的功能。著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。我们采用微服务架构将字段的定制化设计为独【版权所有】唐霜 www.tangshuang.net【本文受版权保护】立于原有业务的服务,再改造原有业务中关于本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】数据读取的逻辑来配合微服务获取最终的结果【转载请注明来源】【作者:唐霜】

【本文受版权保护】著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。

转载请注明出处:www.tangshua【版权所有,侵权必究】转载请注明出处:www.tangshuang.netng.net【访问 www.tangshuang.n原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.netet 获取更多精彩内容】

字段定制服务作为基础服务中的一项,保持自未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。己的数据,通过接口形式与业务服务交互。一【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。个业务服务只针对一个业务提供服务,它会同转载请注明出处:www.tangshuang.net【版权所有,侵权必究】时调度多个基础服务,完成必要的各种功能,著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。其中包含字段定制服务。在请求中,按照上述【本文受版权保护】【未经授权禁止转载】请求逻辑获取数据,并返回给请求方。

【版权所有,侵权必究】【关注微信公众号:wwwtangshua【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。ngnet】【访问 www.tangshuang.n【本文受版权保护】【本文首发于唐霜的博客】et 获取更多精彩内容】【原创不易,请尊重版权】

流程可定制化

业务流程是业务系统的重要一部分,甚至是核【转载请注明来源】原创内容,盗版必究。心部分。业务流程的本质,是提前规划各种触本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。发事件与事件被触发后的行为方式。流程服务【作者:唐霜】本文作者:唐霜,转载请注明出处。已经有比较成熟的解决方案,因此,我们在做原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】流程定制化时,可以把目光集中在定制化这个转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】方面,而对于服务,可以直接寻找适合的成熟著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】方案。本文将会对流程定制化在概念层面进行原创内容,盗版必究。【原创不易,请尊重版权】拆分,让你可以更好的理解业务流程的设计方本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。式。

本文版权归作者所有,未经授权不得转载。【转载请注明来源】著作权归作者所有,禁止商业用途转载。

分析

业务流程简单讲就是业务事件的限定触发与业转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。务对象的变更。流程系统本质上就是一个状态本文作者:唐霜,转载请注明出处。原创内容,盗版必究。机,只不过由于需要和业务结合,并且需要考【本文首发于唐霜的博客】【本文受版权保护】虑到融入整套系统中,在设计上会更加复杂。未经授权,禁止复制转载。【原创内容,转载请注明出处】既然是状态机,那么理解和设计起来就更容易原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。了。

【原创内容,转载请注明出处】【原创内容,转载请注明出处】

一条业务流程分为两个部分:

【关注微信公众号:wwwtangshua本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】ngnet】【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshu【本文受版权保护】【版权所有,侵权必究】ang.net原创内容,盗版必究。
  • 流程图
  • 本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.n【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】【未经授权禁止转载】本文作者:唐霜,转载请注明出处。
  • 流程运行时
  • 【作者:唐霜】原创内容,盗版必究。【转载请注明来源】【关注微信公众号:wwwtangshua【本文受版权保护】著作权归作者所有,禁止商业用途转载。ngnet】

你可以把流程图理解为模型,本质上也就是状未经授权,禁止复制转载。【本文受版权保护】态机。运行时则是在将状态机放在具体的环境著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。中,用一个变量记录当前状态;同时,与程序【版权所有,侵权必究】【本文首发于唐霜的博客】绑定,从而当发生状态变更时,可以执行对应本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net的程序,变更对应的业务对象,从而实现业务转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】推进。

【版权所有】唐霜 www.tangshu本文版权归作者所有,未经授权不得转载。【作者:唐霜】ang.net未经授权,禁止复制转载。未经授权,禁止复制转载。

目前市面上有BPMN标准,该标准目前最新【版权所有,侵权必究】原创内容,盗版必究。版是2.0版本,BPMN的描述语言是xm【原创内容,转载请注明出处】【原创内容,转载请注明出处】l。基于BPMN标准实现的运行时环境有很本文作者:唐霜,转载请注明出处。原创内容,盗版必究。多,我们称这类运行时为BPM。其中比较知著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。名的还有flowable,我们将会采用f【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.netlowable作为我们的运行时,因为它还原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。提供了微服务的API,有利于我们后微服务原创内容,盗版必究。转载请注明出处:www.tangshuang.net化。

著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。ang.net未经授权,禁止复制转载。

流程图由节点、连接组成。节点类型繁多,链【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】接也有很多种。

【访问 www.tangshuang.n【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。et 获取更多精彩内容】【版权所有】唐霜 www.tangshu【版权所有,侵权必究】【本文受版权保护】ang.net

转载请注明出处:www.tangshua【未经授权禁止转载】转载请注明出处:www.tangshuang.netng.net【关注微信公众号:wwwtangshua原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。ngnet】【原创不易,请尊重版权】

流程可定制化中的定制,主要包含定制流程图【版权所有,侵权必究】【本文受版权保护】、定制节点/连接及其上的参数。简单讲,就【版权所有,侵权必究】【未经授权禁止转载】是让我们做到流程不是用代码实现的,而是由【作者:唐霜】【本文首发于唐霜的博客】引擎实现的,改变流程不需要我们改代码,只【转载请注明来源】【版权所有】唐霜 www.tangshuang.net需要我们通过界面操作改流程图即可。这些界【原创内容,转载请注明出处】【本文首发于唐霜的博客】面定制化的内容,我们需要把它放到我们可定【未经授权禁止转载】原创内容,盗版必究。制化系统中去整合。索性flowable提【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net供了非常丰富的接口和素材,我们可以在自己【原创内容,转载请注明出处】【本文首发于唐霜的博客】的系统中编辑流程图和展示流程图。

【关注微信公众号:wwwtangshua【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.netngnet】【本文受版权保护】【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。

从状态机的视角,每一个状态发生变更时,本本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。质上通过触发事件,事件带来行为产生副作用【作者:唐霜】转载请注明出处:www.tangshuang.net。现在,我想的是,在什么地方去执行副作用【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】呢?我想的是,将我们的节点任务以云函数的【关注微信公众号:wwwtangshuangnet】原创内容,盗版必究。形式与节点进行绑定,流程图有多少节点,就【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】实现多少云函数来执行其副作用。这样设计的原创内容,盗版必究。【版权所有,侵权必究】好处是,首先,流程服务与业务解耦,我们不【未经授权禁止转载】【本文受版权保护】需要把业务逻辑侵入流程服务;其次,云函数【转载请注明来源】【版权所有】唐霜 www.tangshuang.net和流程实现可插拔,我们在没有变更流程的情【关注微信公众号:wwwtangshuangnet】原创内容,盗版必究。况下如果需要变更业务逻辑,则只需要修改对未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】应节点的云函数,如果我们不需要修改业务逻【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。辑,只需要通过拖拽流程图即可,这样带来的【转载请注明来源】【版权所有,侵权必究】重新部署的成本非常小;最后,这样可以不受【关注微信公众号:wwwtangshuangnet】【关注微信公众号:wwwtangshuangnet】技术栈的束缚,虽然同一语言有利于管理,但【关注微信公众号:wwwtangshuangnet】【转载请注明来源】在某些场景下,我们可以使用更高效的语言来转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】开发某个节点的业务。

未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。

架构设计

基于上述分析,我们现在大概可以把业务流程【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net拆分为以下几大块:

【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。
  • 流程图管理界面、流程图展示界面组件
  • 未经授权,禁止复制转载。未经授权,禁止复制转载。
  • flowable流程引擎服务
  • 本文作者:唐霜,转载请注明出处。【作者:唐霜】
  • 云函数
  • 【转载请注明来源】【作者:唐霜】【关注微信公众号:wwwtangshua【未经授权禁止转载】【版权所有,侵权必究】ngnet】【作者:唐霜】
  • 业务服务部分
  • 【作者:唐霜】【访问 www.tangshuang.n转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。et 获取更多精彩内容】本文作者:唐霜,转载请注明出处。

我们用一个图来表示业务服务、流程服务、云【关注微信公众号:wwwtangshuangnet】【本文受版权保护】函数的关系:

【版权所有,侵权必究】【本文受版权保护】

未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。

由于流程服务每一条流程起来以后保管自己的著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。当前状态,因此,对于业务服务而言,只需要【转载请注明来源】【未经授权禁止转载】在每次发生变更的时候,向流程服务请求状态著作权归作者所有,禁止商业用途转载。【转载请注明来源】变更即可,流程服务会根据当前状态,调用底【作者:唐霜】【关注微信公众号:wwwtangshuangnet】层的无状态服务进行计算,如果不需要状态流【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】转,就不需要调用云函数,而是直接返回业务【版权所有,侵权必究】【版权所有,侵权必究】服务null,业务服务就知道当前这个变更转载请注明出处:www.tangshuang.net原创内容,盗版必究。不会触发流程变更。

【原创内容,转载请注明出处】【作者:唐霜】本文作者:唐霜,转载请注明出处。

原创内容,盗版必究。【版权所有,侵权必究】【作者:唐霜】

我们将上面的流程引擎服务和流程图服务打包转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。成流程服务提供给系统使用,这样可以提供统【转载请注明来源】【本文受版权保护】一的进出口API,而云函数本质上和其他服【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。务解耦,但会操作共同的底层数据。

著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshua【转载请注明来源】原创内容,盗版必究。ng.net【未经授权禁止转载】【原创不易,请尊重版权】

【转载请注明来源】【本文受版权保护】

虽然我将云函数放在业务服务的范畴,但实际【访问 www.tangshuang.net 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。上它们不会被上层的应用层调用,而是被流程未经授权,禁止复制转载。未经授权,禁止复制转载。服务调用,听上去并不合理,但是由于云函数【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。本质上还是业务逻辑处理,因此,我把它放在著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。了业务服务的范畴内。

【关注微信公众号:wwwtangshua【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。ngnet】【本文首发于唐霜的博客】【作者:唐霜】【未经授权禁止转载】

表单可定制化

表单在业务系统中扮演着极其重要的角色,是【原创不易,请尊重版权】原创内容,盗版必究。必要的部分,你很难想象一个业务系统中没有原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。表单。表单是业务数据生产的地方,在业务对【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net象的创建、编辑过程中,在业务流程的推进过本文作者:唐霜,转载请注明出处。【作者:唐霜】程中,都需要表单来输入数据。但无论在什么【作者:唐霜】本文作者:唐霜,转载请注明出处。场景下,表单的结构体系,都可以被标准化。本文作者:唐霜,转载请注明出处。【转载请注明来源】关于表单,我在之前的文章《动态表单引擎,著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】向低代码迈出最关键的一步》和《Robus【转载请注明来源】转载请注明出处:www.tangshuang.nett 第 014 期:三角金字塔 web 原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net表单开发新范式》中已经较为详细的阐述过,【本文首发于唐霜的博客】【原创不易,请尊重版权】有兴趣可以去看一看。由于此前的文章对动态【版权所有,侵权必究】【版权所有,侵权必究】表单的底层逻辑和设计都梳理的比较清晰了,【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。所以,本文主要将从架构层面,结合可定制化本文作者:唐霜,转载请注明出处。【转载请注明来源】体系,给出比较合理的架构体系。

转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net原创内容,盗版必究。ng.net著作权归作者所有,禁止商业用途转载。

分析

被定制化表单有两部分配置来源,一部分是来原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net自自定定制的元数据,另一部分是来自表单配【本文受版权保护】【原创不易,请尊重版权】置的界面安排。

转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net原创内容,盗版必究。ng.net原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】

未经授权,禁止复制转载。转载请注明出处:www.tangshua未经授权,禁止复制转载。转载请注明出处:www.tangshuang.netng.net【关注微信公众号:wwwtangshua本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】ngnet】

和网上常见的表单定制工具不同,主要有两点【版权所有,侵权必究】【访问 www.tangshuang.net 获取更多精彩内容】

【版权所有,侵权必究】未经授权,禁止复制转载。转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net【本文受版权保护】ng.net
  • 其他方案在表单之前没有真正的字段概念,但未经授权,禁止复制转载。【本文首发于唐霜的博客】在业务系统中,先有字段,才有表单
  • 著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。【转载请注明来源】本文作者:唐霜,转载请注明出处。
  • 其他方案表单中一行就是一个字段,但实际上【版权所有,侵权必究】原创内容,盗版必究。,业务系统中往往字段有强关联性,一行可能【本文首发于唐霜的博客】【版权所有】唐霜 www.tangshuang.net需要填多个字段
  • 本文作者:唐霜,转载请注明出处。【转载请注明来源】【版权所有,侵权必究】【未经授权禁止转载】

同时,在原有字段的定制信息中,还要考虑到转载请注明出处:www.tangshuang.net【转载请注明来源】,不同表单同一字段可能存在不同逻辑。这一著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net点虽然我们可以通过方案来解决,但是我们还著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】是需要在表单中合并特殊逻辑。因此,表单本【未经授权禁止转载】转载请注明出处:www.tangshuang.net身是基于字段的独立实体,会用字段元数据作【本文受版权保护】未经授权,禁止复制转载。为基础数据,在用自己的配置数据与元数据进【作者:唐霜】【转载请注明来源】行合并。

本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。【版权所有,侵权必究】【版权所有】唐霜 www.tangshu【作者:唐霜】未经授权,禁止复制转载。ang.net

表设计

实际上表单的表没有什么特别需要设计的,因本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】为表单的描述是一个静态的配置。

原创内容,盗版必究。【转载请注明来源】本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。

著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua未经授权,禁止复制转载。未经授权,禁止复制转载。ngnet】【本文受版权保护】

就只有一个表,所以没有什么表层面的复杂度本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。,其中的fields用于作为生成conf【本文受版权保护】【版权所有,侵权必究】ig之前的基础信息,由于我们可以在管理平本文作者:唐霜,转载请注明出处。【未经授权禁止转载】台上修改字段的配置信息,所以,字段的基础【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。元数据,需要通过fields动态拉取。表【作者:唐霜】【原创内容,转载请注明出处】单和字段并非一对一的关系,表单中提交的数【原创不易,请尊重版权】【版权所有,侵权必究】据,可能写入到维度业务对象,也可能写入到【作者:唐霜】【版权所有,侵权必究】流程信息,或者写入到文档服务,总之,本质【转载请注明来源】【原创不易,请尊重版权】上,表单本身是独立的,只不过当需要fie【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。lds时,需要依赖字段定制服务。

本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshu【原创不易,请尊重版权】【作者:唐霜】ang.net

架构设计

表单在业务系统中会存在很多很多实例,而且【原创内容,转载请注明出处】【转载请注明来源】每一个都不同。表单最终提交到哪个接口,可未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net以由表单配置本身决定,也可以由调用表单服原创内容,盗版必究。本文作者:唐霜,转载请注明出处。务的业务自己决定。如果想要通过选取的方式【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。决定提交的目标,那么还需要依赖一个分发服【原创内容,转载请注明出处】【原创不易,请尊重版权】务,用于分发请求。我们这里暂时不考虑这一【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】功能。

【访问 www.tangshuang.n【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。et 获取更多精彩内容】【版权所有,侵权必究】未经授权,禁止复制转载。

对于表单业务而言,它的数据流大致如下:

【关注微信公众号:wwwtangshua未经授权,禁止复制转载。【作者:唐霜】ngnet】【本文首发于唐霜的博客】

本文版权归作者所有,未经授权不得转载。【作者:唐霜】

表单引擎不仅可以在业务服务中使用,在流程【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。节点上,也可以用来作为审批等节点操作的表本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。单。但是,这里需要注意,流程引擎本身是业【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。务无关的,具体的业务服务去集成流程和表单转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】,对于表单本身而言,它的数据流和上图是一【转载请注明来源】【原创不易,请尊重版权】致的,只不过提交的表单数据,是用以推进流【未经授权禁止转载】本文作者:唐霜,转载请注明出处。程的。

原创内容,盗版必究。【本文受版权保护】【原创不易,请尊重版权】

【原创内容,转载请注明出处】未经授权,禁止复制转载。【原创不易,请尊重版权】

另外,flowable也有自己的表单引擎【版权所有】唐霜 www.tangshuang.net【作者:唐霜】,但是你需要按照它的设计来使用,不是很符【本文受版权保护】【原创内容,转载请注明出处】合我们现代前端的开发方式。表单引擎是为业本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】务服务的。表单的配置页面和填写页面,都由【版权所有,侵权必究】【转载请注明来源】对应的react组件来承载。

【未经授权禁止转载】【本文受版权保护】本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua未经授权,禁止复制转载。【原创不易,请尊重版权】ng.net

界面可定制化

我们这里讲的界面可定制化,主要包含两个方【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。面:1.数据的展示定制;2.布局的展示定未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】制。其中,布局的展示定制比较像部分低代码【未经授权禁止转载】本文作者:唐霜,转载请注明出处。的实现,但由于我们的业务系统往往比较单调著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。,因此,难度上会小很多。数据的展示定制就【作者:唐霜】【未经授权禁止转载】相对复杂一些,需要前后端有较强的协议来约本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】束接口(前后端耦合)。

【转载请注明来源】【本文受版权保护】【未经授权禁止转载】

分析

数据的展示又分为:1.列表的展示;2.筛【作者:唐霜】本文作者:唐霜,转载请注明出处。选器的展示;3.对象详情信息的展示。常用【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】的定制点包含:1.要展示哪些信息/字段;【原创内容,转载请注明出处】【本文受版权保护】2.它们的顺序是什么;3.要使用那个字段原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net属性方案。更复杂的展示逻辑没有必要让前端【原创不易,请尊重版权】【原创内容,转载请注明出处】来实现,与其通过配置给前端进行解析,不如【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。直接ssr更直接。因此,我认为只需要解决【作者:唐霜】著作权归作者所有,禁止商业用途转载。上述这些可定制点就行了,没必要把整个业务【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】系统用一个JSON写完。

未经授权,禁止复制转载。【本文首发于唐霜的博客】

先来看下列表,列表实际上由表头和数据行组著作权归作者所有,禁止商业用途转载。【转载请注明来源】成,表头和字段的元数据相关,通过表头信息【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.net,我们可以知道一列的数据具体代表了什么意【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net义,要使用什么格式来展示等等。每一行的展转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。示内容,则是根据各列的这些信息,再加上当原创内容,盗版必究。转载请注明出处:www.tangshuang.net前行的数据,最终生成。

本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】

本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】ng.net【本文首发于唐霜的博客】【本文首发于唐霜的博客】

但是,列的顺序是散列的,因此,我们需要有【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】一个配置来记录列的顺序、是否可以过滤、是【本文受版权保护】本文版权归作者所有,未经授权不得转载。否支持排序等等。因此,我们用以保存列表配本文作者:唐霜,转载请注明出处。【本文受版权保护】置的信息里,一方面要记录这个列表所需要哪【本文受版权保护】【作者:唐霜】些字段、字段的排序、字段支持的能力这些信【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net息。因此,如果我们要在一个接口中返回列表【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】数据,至少需要包含三部分信息:列表配置、【未经授权禁止转载】本文作者:唐霜,转载请注明出处。字段元数据(含方案)、列表原始数据。

转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。ng.net本文版权归作者所有,未经授权不得转载。
GET /api/productions
{
  "config": {
    "columns": [
      {
        "key": "field1", // 字段key
        "filterable": 1, // 支持过滤
        "sortable": 1 // 支持排序
      }
    ],
    "scheme": "some"
  },
  "fields": {
     "field1": {
       "formatter": "1.1f",
       "title": "字段名"
     }
  },
  "rows": [
    {
      "field1": 10000
    }
  ]
}

当然,如果还有其他配置的可能,还可以在c【转载请注明来源】【作者:唐霜】onfig中添加,其中,columns是【作者:唐霜】【本文首发于唐霜的博客】该列表的列配置,数组就可以表达它们的顺序【转载请注明来源】【作者:唐霜】

原创内容,盗版必究。【转载请注明来源】未经授权,禁止复制转载。【原创不易,请尊重版权】

【本文受版权保护】【未经授权禁止转载】

不同的用户,甚至可以定制自己的视图。此时原创内容,盗版必究。【转载请注明来源】,存储的配置信息要根据用户来保管。不过上【作者:唐霜】【原创内容,转载请注明出处】图中没有给出是否支持过滤、排序,以及选择本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net哪个方案的配置,这些你可以脑补出来。

【本文受版权保护】原创内容,盗版必究。

筛选器配置本质上和字段配置差不多,也是要本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。与不要,以及顺序问题。

【转载请注明来源】原创内容,盗版必究。【关注微信公众号:wwwtangshua【原创不易,请尊重版权】原创内容,盗版必究。ngnet】

详情页的定制则更偏重布局的配置,不过具体【本文首发于唐霜的博客】原创内容,盗版必究。的某个区域内的配置,也和字段的配置是一样【关注微信公众号:wwwtangshuangnet】原创内容,盗版必究。的。当然,我们可以和前端通过协议来决定一【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。些界面的布局,比如界面上一些区块的排列顺本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】序。

【本文受版权保护】本文版权归作者所有,未经授权不得转载。

架构设计

界面的定制化其实是最简单的一个部分,它不【转载请注明来源】【版权所有】唐霜 www.tangshuang.net需要过度设计,只需要在布局协议上前后端沟未经授权,禁止复制转载。【版权所有,侵权必究】通好就可以了。

【原创不易,请尊重版权】【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。ang.net【关注微信公众号:wwwtangshua【本文首发于唐霜的博客】【本文首发于唐霜的博客】ngnet】

【版权所有,侵权必究】【本文首发于唐霜的博客】未经授权,禁止复制转载。

结语

本文详细阐述了业务系统可定制化中的字段定本文作者:唐霜,转载请注明出处。【作者:唐霜】制化、流程定制化、表单定制化、界面定制化【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。的设计思路和方法。业务系统与那些通用的系【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。统之间有着明确的区别,即业务系统有非常明【关注微信公众号:wwwtangshuangnet】【关注微信公众号:wwwtangshuangnet】确的领域边界,业务内某些逻辑是固定的,这【本文受版权保护】未经授权,禁止复制转载。些固定的,或领域特有的,就没有必要做成通【本文受版权保护】【原创内容,转载请注明出处】用化的东西,而应该提炼成独立的领域组件,【关注微信公众号:wwwtangshuangnet】【作者:唐霜】这样才能避免无止尽的自定义搭建,同时也可【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。以避免通用自定义搭建系统无法实现某些具体原创内容,盗版必究。未经授权,禁止复制转载。逻辑的问题。

【访问 www.tangshuang.n未经授权,禁止复制转载。未经授权,禁止复制转载。et 获取更多精彩内容】原创内容,盗版必究。

虽然本文展示了自己的架构设计,但是,这个【本文受版权保护】本文版权归作者所有,未经授权不得转载。设计是建立在整套系统通盘考虑都基于微服务【版权所有,侵权必究】【访问 www.tangshuang.net 获取更多精彩内容】搭建,但在真实场景中,我们的业务系统往往【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。是从最初的单体应用发展而来的,原有的设计未经授权,禁止复制转载。原创内容,盗版必究。不一定可以服务化,而如果推翻重来,风险也本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。很大。因此,我们上面的这套设计,还可以兼本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】容已有的系统,或者说,现有的这套正在运行【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net的单体,对于定制化体系,是可有可无的,如原创内容,盗版必究。【版权所有,侵权必究】果想花功夫接入定制化系统,那么可以在原来著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。的系统上做好粘合,就可以逐渐迁移,避免高未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】成本的一次性重构带来的风险。

转载请注明出处:www.tangshua原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。ng.net【未经授权禁止转载】【版权所有】唐霜 www.tangshu【本文受版权保护】【作者:唐霜】ang.net【本文受版权保护】

2021-10-21 10201

为价值买单,打赏一杯咖啡

本文价值102.01RMB