likes
comments
collection
share

如何从无到有搭建一套完整的低代码平台(一)项目搭建

作者站长头像
站长
· 阅读数 40

一. 介绍

目前市面上大量成熟的低代码平台可以供我们使用和研究。但是个人觉得还是有必要去从0实现一套低代码平台。最主要我们要从中了解到一套完整低代码平台设计的思想。

二. 项目目录

考虑到项目前后端都有,我们需要根据功能进行拆分。

1. packages

核心的功能包packages

如何从无到有搭建一套完整的低代码平台(一)项目搭建

现阶段先把packages拆分成为5个核心包

  • commonUI(项目使用的UI库)
  • client (前端核心)
  • server (后端核心)
  • types (TS类型声明)
  • tools (辅助工具)

2. script

用做打包时候的一些脚本配置

如何从无到有搭建一套完整的低代码平台(一)项目搭建

没什么好说的,暂时分成dev和prod环境

3. qa-core

编写单元测试的文件

三. 项目搭建

考虑到目前是多包管理,有各自独立的版本,每个子包之间互相依赖,结合现在社区比较活跃的多仓模式。我选择使用monorepo。包管理工具我这里选择使用pnpm

1. 目录初始化

在本地新建一个lowCaseSixMembered(我自己的文件夹,大家取名字随意)此为项目的根目录

注意:保证自己的node > 16版本才可以使用pnpm

在lowCaseSixMembered下: pnpm init

初始化项目然后修改package.json文件里面的name字段

    "name": "low-case"

low-case就是你项目的文件名

新建三个文件夹

  • packages
  • qa-core
  • script

其他两个先不管他,主要关心packages里面

2. packages目录

先进到packages文件夹里面。然后执行pnpm init 同样的步骤修改一下package.json文件里面的name字段。

    "name": "six-membered"

按照上面的文件新建5个文件

  • client
  • commonUI
  • server
  • tools
  • types
    // 分别进到对应的文件夹中init一下
    cd client && pnpm init

修改一下对应的package.json

    "name": "@six-membered/client"

这里注意一下name,最好使用@开头。表示都是同一个包下面的子包。具体name属性可以看文档 docs.npmjs.com/organizatio…

3. 建立包之间的联系

回到根目录,我们如何在互相引用packages里面的子包呢?这里就要使用到pnpm了。 在根目录上创建 pnpm-workspace.yaml文件 可以在该配置文件中指定这个仓库中有多少个项目。

    // pnpm-workspace.yaml
    packages:
          - 'packages/*'
          - 'qa-core'
          - 'script'

互相调用。 在根目录执行:

    pnpm install @six-membered/client  -w
    pnpm install @six-membered/tools  -w
    pnpm install @six-membered/server  -w
    pnpm install @six-membered/ui  -w

-w 表示安装到共公模块的 package.json 中,也就是根目录下的 package.json。

这时候根目录会出现一个node_modules,看一下文件结构:

如何从无到有搭建一套完整的低代码平台(一)项目搭建

表示packages下面的子项目都以软链的形式添加到对应的依赖包中。

4. 测试

  1. 在tools中新建文件夹src/index.js
    export const myTest = () => console.log(11111111);

修改package.json文件

如何从无到有搭建一套完整的低代码平台(一)项目搭建 main指定入口文件。 type = module 表示模块使用es6加载

  1. 在client文件中新建文件夹src/index.js 同样修改package.json文件(同上) 修改index.js里面的代码:

如何从无到有搭建一套完整的低代码平台(一)项目搭建

然后在控制台执行:

如何从无到有搭建一套完整的低代码平台(一)项目搭建

可以看到模块被成功加载和执行。 基本搭建到这里就完成了,接下来按照步骤一步一步来实现就好

转载自:https://juejin.cn/post/7269985726081826868
评论
请登录