AI + 低代码技术揭秘(二):核心架构

简介: VTJ低代码平台架构包含引擎编排层、Provider服务系统、数据模型及代码生成管道,支持设计时与运行时功能。Engine管理设计流程,Provider处理服务加载,Simulator实现组件渲染,数据模型通过事件驱动同步状态。代码生成管道可双向转换Vue组件与DSL,支持多平台适配,如Web、H5和UniApp。系统提供可视化编辑、热重载与AI集成,满足高效开发需求。

本文档介绍了为 VTJ 低代码平台提供支持的基本架构组件,包括 Engine 编排层、Provider 服务系统、数据模型和代码生成管道。有关 UI 组件库和 widget 系统的信息,请参阅 UI 组件库 。有关特定于平台的实施,请参阅平台实施 。

引擎、提供商和服务层

VTJ 架构围绕三个主要编排组件构建:用于设计时管理的 Engine、用于运行时服务的 Provider 和用于基于 iframe 的渲染的 Simulator

设计时引擎架构

Engine 充当设计时环境的中央业务流程协调程序。它通过几个关键职责来管理整个生命周期:

  • 项目管理 :通过 Service 界面协调 ProjectModel 实例和文件操作
  • 模拟器控制 :管理模拟器以进行基于 iframe 的组件渲染和预览
  • Asset Management:通过 Assets 类处理材质加载和组件注册
  • 事件协调 :绑定到模型事件以实现实时更新和持久性

Provider 服务架构

Provider 类跨不同执行模式(ContextMode.DesignContextMode.RuntimeContextMode.Raw)管理运行时服务和资源加载。关键架构模式包括:

  • 资源加载 :根据项目配置异步加载依赖项、材料和组件
  • API 管理 :通过 createSchemaApis 创建和管理基于 schema 的 API
  • 组件注册 :动态组件解析和 Vue 插件安装
  • DSL 渲染 :用于创建将 BlockSchema 转换为 Vue 组件的渲染器的工厂方法

项目模型和块模型

数据层以反应式模型为中心,这些模型通过事件驱动架构管理项目状态和组件定义。

模型层次结构和事件

ProjectModel 管理完整的项目状态,包括页面、块、依赖项和配置。它实现了几个关键模式:

  • 文件管理PageFileBlockFile 的 CRUD 操作,包括验证和事件发出
  • 依存关系管理 :外部库和材料的动态加载和版本管理
  • 状态同步 :事件驱动的更新,通过 Service 层触发持久性
  • 平台适配:支持不同目标平台(webh5uniapp

关键作包括用于文件管理的 createPage()createBlock()setDeps()active(), 每个作都会触发相应的事件以进行 UI 同步。

块模型和节点层次结构

BlockModel 将单个组件或页面表示为 NodeModel 实例的树。该架构支持:

  • 层次结构 :基于插槽的内容组织的父子关系
  • 组件集成 :通过 MaterialDescription 和 NodeFrom 配置动态加载组件
  • 状态管理 :具有锁定、可见性和验证状态的响应式属性
  • 序列化:运行时模型和可序列化 BlockSchema/NodeSchema 之间的双向转换

代码生成和解析管道

VTJ 通过复杂的解析和代码生成管道实现 Vue 单文件组件 (SFC) 和低代码 DSL 之间的双向转换。

DSL 到组件渲染管道

渲染管道通过几个阶段将 BlockSchema 定义转换为可执行的 Vue 组件:

  • DSL 加载 :createLoader 函数创建一个递归解析组件依赖关系的 BlockLoader
  • 组件解析 :NodeFrom 配置指定如何加载组件(SchemaUrlSchemaPlugin 类型)
  • 异步组件创建 :Vue 的 defineAsyncComponent 支持通过 loaders 进行缓存的延迟加载组件
  • 上下文集成 :CreateRendererOptions 提供包括 Vue 实例、组件库和 API 在内的运行时上下文

Vue SFC 解析和代码生成

双向转换系统支持视觉设计和代码之间的无缝过渡:

  • 解析器集成@vtj/parser将 Vue SFC 转换为 BlockSchema 以进行可视化编辑
  • 代码生成@vtj/coder 包从 BlockSchema 定义生成完整的 Vue 项目
  • 服务层 :通过 Service.saveFile()Service.getFile() 进行的文件作保持同步
  • AI 集成Engine.applyAI() 方法使 AI 生成的 DSL 能够集成到设计工作流程中

Engine.genSource() 方法编排完整的代码生成过程,而 createRawPage() 支持具有可视化组件和基于代码的组件的混合工作流。

运行时架构和上下文管理

运行时系统通过分层上下文架构管理不同模式和平台上的组件执行

上下文和模式管理

运行时体系结构根据 ContextMode 调整行为:

  • 设计模式 :完整的设计时功能,带有热重载和可视化编辑工具
  • 运行时模式 :针对生产部署优化组件执行
  • Raw 模式:直接执行 Vue 组件,无低代码开销

模拟器会创建一个隔离的 iframe 环境 (contentWindow),其中包含自己的 SimulatorEnv

  • 组件注册表:从 Materials 和 dependencies 解析的组件
  • API 层 :具有模拟数据支持的基于 Schema 的 API
  • 平台适配器Webuniapp 平台的不同应用程序创建策略

多平台运行时适配

特定于平台的运行时创建可处理不同的执行环境:

  • Web 平台 :带有 Vue 路由器和 DOM 安装的标准 Vue 应用程序
  • UniApp 平台 :使用 setupUniApp()UniH5 运行时集成进行专门设置
  • 插件安装 :根据依赖项配置自动安装库插件
  • 路由器配置:具有不同历史模式的平台适当路由设置

Provider.install() 方法管理跨平台的插件安装和全局属性设置。



源码仓库

https://gitee.com/newgateway/vtj

相关文章
|
28天前
|
人工智能 数据安全/隐私保护
如何识别AI生成内容?探秘“AI指纹”检测技术
如何识别AI生成内容?探秘“AI指纹”检测技术
325 119
|
28天前
|
机器学习/深度学习 人工智能 自然语言处理
AI检测技术:如何识别机器生成的“数字指纹”?
AI检测技术:如何识别机器生成的“数字指纹”?
233 115
|
28天前
|
人工智能 自然语言处理 算法
揭秘AI文本:当前主流检测技术与挑战
揭秘AI文本:当前主流检测技术与挑战
309 115
|
1月前
|
人工智能 vr&ar UED
获奖公布|第十九届"挑战杯"竞赛2025年度中国青年科技创新"揭榜挂帅"擂台赛阿里云“AI技术助力乡村振兴”专题赛拟授奖名单公示
获奖公布|第十九届"挑战杯"竞赛2025年度中国青年科技创新"揭榜挂帅"擂台赛阿里云“AI技术助力乡村振兴”专题赛拟授奖名单公示
|
1月前
|
人工智能 新制造
TsingtaoAI受邀参加宁波AI海曙科创训练营并分享技术落地实践
10月12日至15日,由宁波市海曙区组织部主办的AI海曙科创训练营在宁波成功举办。作为受邀企业代表,TsingtaoAI团队深入参与了多项活动,与政府领导、行业专家及科创企业代表围绕AI技术在制造业、成果转化等领域的实际应用展开交流,用真实案例诠释了“技术扎根产业”的价值逻辑。
79 2
|
1月前
|
存储 缓存 安全
某鱼电商接口架构深度剖析:从稳定性到高性能的技术密码
某鱼电商接口架构揭秘:分层解耦、安全加固、性能优化三维设计,实现200ms内响应、故障率低于0.1%。详解三层架构、多引擎存储、异步发布、WebSocket通信与全链路防护,助力开发者突破电商接口“三难”困境。
|
1月前
|
机器学习/深度学习 人工智能 算法
AI可以做电商主图了:技术原理,AI电商图生成工具对比及技术解析
双十一临近,电商主图需求激增。AI技术凭借多图融合、扩散模型等,实现高效智能设计,30秒生成高质量主图,远超传统PS效率。支持风格迁移、背景替换、文案生成,助力商家快速打造吸睛商品图,提升转化率。
563 0
|
28天前
|
机器学习/深度学习 人工智能 自然语言处理
如何准确检测AI生成内容?这三大技术是关键
如何准确检测AI生成内容?这三大技术是关键
521 116
|
1月前
|
人工智能 机器人 人机交互
当AI学会“看、听、懂”:多模态技术的现在与未来
当AI学会“看、听、懂”:多模态技术的现在与未来
264 117

热门文章

最新文章