逻辑编排 - DragFlow

很多平台提供的低代码平台,其实都是通过一个设计器设计后生成的DSL配合一个运行时来生成最终产品的方案。
比如要做一个页面,放置一个按钮,在点击按钮后需要请求一个接口然后根据请求结果来判断弹出一个弹窗还是展示Toast,那么一般的低代码工具所给出的简单方案都不足以满足条件,因为他们只提供了简单执行单元(请求接口或者弹出弹窗等,无法做到这些单元的编排),或者他们会给出直接写代码的入口。
那么如何可视化地来完成这种编排呢?那便是逻辑编排了,通过已有过程库或者自定义实现过程,就可以实现可视化逻辑编排了。

DragFlow

体验:https://tangula.gitee.io/editor

  1. DragFlow是一个实现了可视化逻辑编排、依赖管理、项目管理和预览功能的开发平台。
  2. DragFlow不仅仅只用于前端开发,也可用于后端(NodeJs),因为目前仅实现了TypeScript的解析,所以只能跑在jsvm环境,后续会增加其他语言的实现。
  3. 使用者也可以自己发布npm包到npm库或者部署私有npm镜像库。
  4. 以后DragFlow会封装成通用组件供使用者内嵌到自己的项目中。

Demo

以下的截图是一个通过DragFlow编辑生成的贪吃蛇游戏,该项目在编辑器里的项目模板中有,可以选择并跑起来。


当然,一个完整玩法的贪吃蛇实现起来,其逻辑图是非常很混乱的,这也是逻辑编排的一个弊端,就是当复杂度到达一定的程度后,其可读性就会变得很差。
所以,DragFlow比较合适用于复杂度不那么高的项目,当然,要用也是可以的。

问答

目前已经很多人联系到我并询问了一些问题,重点如下:

  • DragFlow开源吗?---> DragFlow这个工具目前不开源,目前只能用作免费试用和参考,使用者可根据几个内置的npm包自己制作组件包使用
  • DragFlow和NodeRed的区别?---> NodeRed是笔者在做完DragFlow第一版后才在网上发现的,功能较单一,只能进行节点编排,且没有节点选项;DragFlow则是一个完整的图灵完备的产品
  • DragFlow开发了多久?---> 笔者单人开发了近四个月(业余时间)

有意者可联系微信:rockyf,备注:dragflow

posted @ 2022-08-30 01:09  RockyF  阅读(406)  评论(0编辑  收藏  举报