开源无代码 /低代码平台 NocoBase 0.20:支持多数据源
NocoBase 是一个极易扩展的开源无代码开发平台。完全掌控,无限扩展,助力你的开发团队快速响应变化,显著降低成本。不必投入几年时间和数百万资金研发,只需要花几分钟部署 NocoBase。
官方文档:https://docs-cn.nocobase.com/
新特性
支持多数据源
新增「数据源管理」插件,用于管理所有数据源的数据表和字段,数据源管理插件只是提供中心化的数据源管理界面,并不提供接入数据源的能力,需要和各种数据源插件搭配使用,目前支持的数据源包括:
- 主数据库 Main:NocoBase 主数据库,支持 MySQL、PostgreSQL、SQLite 等关系型数据库。
- 外部 MySQL 数据源:接入已有的 MySQL 数据库作为数据源。
- 外部 MariaDB 数据源:接入已有的 MariaDB 数据库作为数据源。
- 外部 PostgreSQL 数据源:接入已有的 PostgreSQL 数据库作为数据源。
除此之外,也可以扩展更多数据源,可以是常见的各类数据库,也可以是提供 API(SDK)的平台。
调整数据表的管理方式
将原来的「数据表管理」移至「数据源 > 主数据库 > 配置」
支持非 ID 字段作为主键和关系约束
建表时,可以不选择创建 ID 字段
整数字段可以作为主键
单行文本字段也可以作为主键
关系约束支持选择其他设置了 Unique 索引的非主键字段
调整拖拽排序
新增「排序」类型字段,建表时不再自动生成排序字段,需要自己手动创建
当选了某个字段作为分组时,将先分组再排序
表格拖拽排序时,需要选择排序字段
创建看板区块时,需要选择排序字段
调整用户和权限界面
新增用户管理界面,并将用户、角色的管理统一到一个菜单内
调整角色管理的界面,便于管理角色关联的用户、权限、部门等数据
将原来的「操作权限」移至「数据源」标签页
部门插件
以部门来组织用户,设定上下级关系,绑定角色控制权限,并支持作为变量用于工作流和表达式。
工作流:审批
审批插件提供了专用的工作流类型(触发器)“发起审批”和专用于该流程的“审批”节点,结合 NocoBase 特有的自定义数据表和自定义区块,可以快速且灵活地创建与管理各类审批场景。
审批配置
审批处理
进一步可通过文档了解:工作流:审批
工作流:结束流程节点
该节点执行时将立即结束当前执行的工作流,并以节点配置的状态结束。通常用于特定逻辑的流程控制,在满足某些逻辑条件后,跳出当前工作流,不再继续执行后续流程的处理。可类比编程语言中的 return 指令,用于退出当前执行的函数。
进一步可通过文档了解:工作流:结束流程节点
工作流:自定义变量节点
可在流程中声明变量,或为已声明的变量赋值,通常用于在流程中保存一些临时数据。适用于一些需要在分支内将计算结果储存到分支外使用的场景(如循环、并行等)。
进一步可通过文档了解:工作流:自定义变量节点
工作流:请求拦截器
请求拦截器插件提供了一种可以对表单的操作请求进行拦截的机制,拦截事件会在对应的表单操作提交后且被处理之前触发。如果在触发后的流程中有“结束流程”节点被执行,或者其他节点执行失败(出错或其他未能执行完成的情况),则该表单操作将被拦截,否则预定操作将被正常执行。搭配使用“响应消息”节点可以为该流程配置返回客户端的响应消息,以对客户端给出相应的提示信息。请求拦截器可用于进行业务验证或逻辑检查,以通过或拦截客户端提交的创建、更新和删除等操作请求。
进一步可通过文档了解:工作流:请求拦截器
工作流:响应消息节点
响应消息节点用于在特定类型的流程中(如请求拦截和表单事件)向提交操作的客户端反馈流程中自定义的消息。
节点配置
提示信息
进一步可通过文档了解:工作流:响应消息节点
不兼容的变化
命名相同但有冲突的 API
这一次的内核变更,有些新版 API 与旧版命名存在冲突,这些有冲突的旧版 API 在这一版里还会保留,但是会统一加上 _deprecated
后缀。
原来的 API | 废弃的 API | 新 API |
---|---|---|
CollectionProvider | CollectionProvider_deprecated | CollectionProvider |
useCollection | useCollection_deprecated | useCollection |
useCollectionField | useCollectionField_deprecated | useCollectionField |
useCollectionManager | useCollectionManager_deprecated | useCollectionManager |
useContext(CollectionManagerContext) | useCollectionManager_deprecated | useCollectionManager |
如果用到以上相关 API,你可以有两种更改方式:
- 简单替换:将原来的 API 替换为带
_deprecated
,例如将useCollection()
替换为useRecord_deprecated()
- 按照新文档使用新 API:虽然新 API 的名称和老 API 相同,但是参数和返回值存在差异,需要参考新文档调整相应代码
其他需要调整的 API
registerTemplate()
变更为app.dataSourceManager.addCollectionTemplates()
registerField()
变更为app.dataSourceManager.addFeildInterfaces()
registerGroup()
变更为app.dataSourceManager.addFieldInterfaceGroups()
useContext(CollectionManagerContext)
变更为useCollectionManager_deprecated()
- 使用
ExtendCollectionsProvider
扩展 collections RecordProvider
需要 parent 参数时,必须显式传入
变更示例说明
Collection Template 扩展
定义
之前是对象定义的方式,现在需要改为类的方式。 例如:
之前
import { ICollectionTemplate } from '@nocobase/client'; const calendar: ICollectionTemplate = { name: 'calendar', title: 'Calendar collection', order: 2, color: 'orange', // ... }
现在
import { CollectionTemplate } from '@nocobase/client'; class CalendarCollectionTemplate extends CollectionTemplate { name = 'calendar'; title = 'Calendar collection'; order = 2; color = 'orange'; }
原来的对象属性变为类的成员。
注册
之前是通过 registerTemplate
注册的,现在需要通过插件的 dataSourceManager.addCollectionTemplates
注册。例如:
之前
import { registerTemplate } from '@nocobase/client'; import { calendar } from './calendar' registerTemplate('calendar', calendar);
现在
import { Plugin } from '@nocobase/client'; import { CalendarCollectionTemplate } from './calendar' export class CalendarPluginClient extends Plugin { async load() { this.app.dataSourceManager.addCollectionTemplates([CalendarCollectionTemplate]); } }
Field Interface 扩展
定义
之前是对象定义的方式,现在需要改为类的方式。 例如:
之前
import { IField } from '@nocobase/client'; const attachment: IField = { name: 'attachment', type: 'object', group: 'media', title: 'Attachment', // ... }
现在
import { CollectionFieldInterface } from '@nocobase/client'; class AttachmentFieldInterface extends CollectionFieldInterface { name = 'attachment'; type = 'object'; group = 'media'; title = 'Attachment'; // ... }
原来的对象属性变为类的成员。
注册
之前是通过 registerField
注册的,现在需要通过插件的 dataSourceManager.addFieldInterfaces
注册,并且不需要 CollectionManagerProvider
再次传递。例如:
之前
import { registerField } from '@nocobase/client'; import { attachment } from './attachment' - registerField(attachment.group, 'attachment', attachment); export const FileManagerProvider: FC = (props) => { return ( - {props.children} - ); };
现在
import { Plugin } from '@nocobase/client'; import { AttachmentFieldInterface } from './attachment' export class FilPlugin extends Plugin { async load() { this.app.dataSourceManager.addFeildInterfaces([AttachmentFieldInterface]); } }
Field Interface Group 扩展
之前是通过 registerGroup
注册的,现在需要通过插件的 dataSourceManager.addFieldInterfaceGroups
注册。例如:
- import { registerGroup, Plugin } from '@nocobase/client'; + import { Plugin } from '@nocobase/client'; - registerGroup('map', { - label: 'Map-based geometry', - order: 10 - }) export class MapPlugin extends Plugin { async load() { + this.app.dataSourceManager.addFieldInterfaceGroups({ + map: { + label: generateNTemplate('Map-based geometry'), + order: 51, + }, + }); } }
useContext(CollectionManagerContext)
改为 useCollectionManager_deprecated()
- const ctx = useContext(CollectionManagerContext); + const ctx = useCollectionManager_deprecated();
扩展 collections,使用 ExtendCollectionsProvider
代替 CollectionManagerProvider
const Demo = () => { - + ... - + }
RecordProvider 的变更
之前在不传入 parent 属性的时候,会自动获取上一级的 RecordProvider 的值作为 parent。现在则需要显式的传入 parent,当不传 parent 的时候,parent 的值将是 undefined。
- + ...
如果没有历史包袱,也可以直接使用 CollectionRecordProvider 替换
- + ... - +
⚠️RecordProvider 和 CollectionRecordProvider 的区别
- RecordProvider 已废弃,未来会被移除
- RecordProvider 带了旧的 RecordContext,CollectionRecordProvider 没有
访问 NocoBase 官网
您可以在官网申请 Demo 演示,体检站点将在 1 分钟内创建完毕自动发送到您的邮箱。
也可以直接访问 GitHub ,下载 NocoBase 源码并安装。支持Docker 安装、create-nocobase-app 安装和 Git源码安装。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
DjangoAdmin 敏捷开发框架 FastAPI+EleVue 版本 v2.2.0 发布
v2.2.0 更新内容:1、解决编辑用户密码误被清空的问题;2、解决编辑会员密码误被清空的问题;3、优化系统权限架构,提升使用体验;4、删除系统中废弃的代码;5、修复近期用户反馈的问题; 一款基于 Fastapi、Vue、ElementUI、MySQL 等技术栈研发的前后端分离开发框架,设计之初就定位为一款高端产品,采用全新的架构设计,后端服务和前端都是采用全新的设计方案,兼容手机、PAD 和 PC 电脑端,具备良好的用户使用体验;框架拥有完善的 (RBAC) 权限架构和基础核心管理模块,权限控制精细化到按钮节点级别颗粒度控制,根据不同的角色分配不同的权限即可实现;为了避免重复造轮子,系统本身已经集成了基础模块,包括常规的权限管理、字典、配置、行政区划等等常规模块;开发者可以基于框架做二次开发,可以用户个人项目、公司项目以及客户定制化项目,本框架为一站式系统框架开发平台,可以帮助开发者提升开发效率、降低研发成本,同时便于后期的系统维护升级。 软件信息 软件名称:DjangoAdmin 敏捷开发框架 FastAPI+EleVue 版本 官网网址:https://www.djangoadm...
- 下一篇
AIGC图像技术在淘宝人生2的探索和应用
淘宝人生2(又名:第二人生)是淘宝的一个虚拟人装扮类应用,承担了用户在淘宝的第二个人生的作用。我们旨在通过AI为淘宝人生2的用户提供丰富有趣的可玩性内容,随着最近火热的AIGC技术的发展,我们也进行了相关尝试和落地,目前已经上线了AI拍照风格化、AI写真馆、AI服饰涂鸦等项目。本文主要以AI服饰涂鸦为例介绍我们在AIGC图像领域的探索和应用,希望能够对大家有所启发和帮助,也欢迎大家建议和合作。 项目背景 为了能够让淘宝人生2的用户拥有更多可互动性的有趣玩法,提高社区内容发布量,我们开发了AI服饰涂鸦项目,能够让用户自行创作生成相关服饰,增加用户的参与感和成就感。具体玩法主要是:通过选定一张底图,用户可以在图上进行自由涂鸦和创作,同时也支持输入文字描述,然后通过AIGC算法技术,最终生成和用户涂鸦相像的高质量风格图像。下列涂鸦来自淘宝人生2的用户创作: 图1 AI服饰涂鸦示例 前置技术介绍 本节内容主要是简介一些项目使用到的关键技术,不会长篇大论进行具体的理论分析,只是让大家有一个大致的了解,如果想深入了解相关的原理可以查看论文或者网上大佬们的文章博客。 ▐Stable Diffusio...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- SpringBoot2全家桶,快速入门学习开发网站教程
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- 2048小游戏-低调大师作品
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS6,CentOS7官方镜像安装Oracle11G