🚀 被迫认识低代码 之 Oinone上手二开前端组件

"领导让我试试用 Oinone 开发 ,于是我有了这篇笔记。"

一来希望自己养成记录习惯,二来规避反复踩坑过程, 三来希望对后续要用到此平台的朋友有帮助


1️⃣ 开发准备

Node.js

  • 官方直接展示使用:v20.16.0

项目代码

  • 开源版:拉取官方示例仓库(前端 oinone-frontend-*-tutorials,后端 oinone-backend-*-tutorials
  • 企业版:找公司对接人要
bash 复制代码
    git clone https://github.com/oinone/oinone-frontend-starter.git

    # Clone with SSH
    git clone git@github.com:oinone/oinone-frontend-starter.git

    # 或者直接去 Gitee 仓库
    https://gitee.com/oinone

2️⃣ 探索一下 Oinone 前端项目

项目结构

  • 使用 多包管理,区分通用组件与私有组件
  • 值得在常规开发中借鉴,后续计划单独写一篇笔记(开心的挖下第一个坑)

核心组件

  • Mask(母版) :页面框架(顶部栏 / 侧边栏)
  • Layout(布局) :某类视图的内容分区(如表格视图主区域)
  • Element(组件) :真正的可视化元素(按钮、卡片、图表)

💡 个人理解:相当于向二次开发人员开放了 6 个接口,自定义组件后按类型存放、替换


3️⃣ 官方的案例:计数器

组件开发与注册

  • 常规 Vue + TS 开发
  • 通过 props 获取 TS 文件中的方法
  • 采用类的方式写组件,区别于常规 Vue 编码
  • 需注意:别漏掉 @Widget.* 装饰器

示例(vue 文件):

示例(TS 文件):

typescript 复制代码
    #TS文件
    import { BaseElementWidget, SPI, Widget } from '@oinone/kunlun-dependencies';
    import Counter from './Counter.vue';

    @SPI.ClassFactory(
      BaseElementWidget.Token({
        widget: 'Counter'
      })
    )
    export class CounterWidget extends BaseElementWidget {
      public initialize(props) {
        super.initialize(props);
        this.setComponent(Counter);
        return this;
      }

      // 导入value
      @Widget.Reactive()
      public value: number = 0;


      // 导入方法
      @Widget.Method()
      public onIncrement() {
        this.value += 1;
      }
    }

最后需 注册组件,即可在平台内调用。

4️⃣ 实际开发复杂组件

  • 支持使用第三方库(如 Ant Design Vue)
  • 'BMDX' 主要是用在拖拉拽中注册使用,请大家忽略我的命名规范问题
  • 👉 后续计划继续研究并分享 M2O / O2M 等等特性。(挖下第二个坑)

🧾 小结一下

这篇笔记的目标是 快速上手 Oinone 前端开发

  • 开发准备:明确 Node.js 版本 & 仓库来源,保证环境一致。
  • 项目结构:多包管理,让通用与私有组件分离,便于复用与治理。
  • 组件开发:TS + 装饰器方式组织逻辑,Vue 负责展示与交互。
  • 复杂场景:可灵活调用子组件、引入第三方库,但要关注继承关系。
相关推荐
有颜有货1 天前
织信低代码:用更聪明的方式,把想法变成现实!
低代码
得帆云低代码1 天前
与200+位CIO对话后,我们发现五个低代码选型的“隐性关注点”(下)
低代码
得帆云低代码1 天前
与200+位CIO对话后,我们发现五个低代码选型的“隐性关注点”(上)
低代码
幂简集成2 天前
通义灵码 AI 程序员低代码 API 课程实战教程
android·人工智能·深度学习·神经网络·低代码·rxjava
CORNERSTONE3652 天前
热烈庆祝“中国抗战胜利80周年”,织信低代码助力国之重器砥砺前行!
低代码
xiaozhazha_2 天前
快鹭云业财一体化系统技术解析:低代码+AI如何破解数据孤岛难题
人工智能·低代码
低代码布道师3 天前
少儿舞蹈小程序(7)打造您的“活”名片:动态展示机构实力
低代码·小程序
Access开发易登软件3 天前
Access开发导出PDF的N种姿势,你get了吗?
后端·低代码·pdf·excel·vba·access·access开发
低代码布道师3 天前
少儿舞蹈小程序(8)校区信息后台搭建
低代码·小程序
阿三08123 天前
钉钉 AI 深度赋能制造业 LTC 全流程:以钉钉宜搭、Teambition 为例
人工智能·低代码·钉钉·teambition