Skip to the content.

这是一款让人上瘾的新一代开发神器,彻底告别Controller、Service、Dao等传统开发方式。

前言

“偷懒”可以说是技术创新非常重要的原因之一,很多技术,框架的革新,本质上就是为了能更好的”偷懒”,FastBuilder在让开发者最大程度“偷懒”的同时,扩展了前端开发者的工作领域且无需额外的学习成本。

什么是FastBuilder?

“FastBuilder” 基于java17 和 vue3 快速开发框架,服务端99.99%以上的功能只需要配置数据模型编写“Fast脚本”就能完成开发,另外剩下的0.01%也可以通过FastBuilder内置的API,一两行代码就可以搞定!不需要发布部署,不需要重启来实现研发团队的快速编码,提测以及回归。实现了服务端研发效率600%-900%的提升,人力成本减少了5倍。

定位

  1. 拒绝CRUD。用尽可能简单的方式,完成尽可能多的需求。通过约定的方式实现统一的标准。告别加班,拒绝重复劳动,远离搬砖。
  2. 开发者全栈化,仅需一名前端程序员就可以独立完成整个项目的开发工作。
  3. 省去编译、部署、发布成本,所写即所得,实时预览最终结果。

特性

传统标准的开发步骤

FastBuilder开发步骤

介于FastBuilder与现有的开发步骤差异过大,更多的细节不在这里一一罗列,可以再实际使用中体验到各种细节的改进,比如自动同步数据库数据结构、形参自校验、快速的模型描述语言等。

快速开始

前期准备工作

创建数据库

这里使用Docker来安装MYSQL

docker run --name mysql -e MYSQL_ROOT_PASSWORD=root \
    -v /home/mysql/data:/var/lib/mysql \
    -p 3306:3306 \
    -d mysql:8.0.18 \
    --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --max_connections=4096

创建完MYSQL后,创建一个库,比如“example_db”,之后的介绍都会在“example_db”库中进行。

docker exec -i mysql sh -c 'exec mysql -uroot -proot -P 3306 -h 127.0.0.1 -e "CREATE DATABASE `example_db`;"'

安装FastBuilder

这里的FastBuilder是安装在开发服务器中,并非客户机,因此客户机不需要额外安装任何工具,只需要有一个浏览器即可。 安装FastBuilder的时候,配置好刚才创建的数据库, 如下:

docker run --name=fast-builder \
    -p 8080:8080 -p 8888:8888 \
    -e MYSQL_HOST=172.17.0.1:3306 \
    -e MYSQL_DB_NAME=example_db \
    -e MYSQL_USERNAME=root \
    -e MYSQL_PASSWORD=root \
    -d guoshengkai/fast-builder:latest

此时访问开发端口:http://localhost:8888, 看到以下页面即为安装成功: 首次启时会拉取相应的前端依赖,动稍等片刻,即可通过访问 http://localhost:8080 看到实时预览页面: 首次部署后,会自动创建一个“example”模块,通过开发者界面可以看到:

通过欢迎页面,我们可以看到fast-builder.config.js是整个项目的核心配置文件,现在我们试着修改他的主页。

开发工作

创建一个模型

models中创建Persion模型:

Persion('my_persion', '人员'){
    string persionName('persion_name', '人员姓名');
    int persionSex('persion_sex', '人员年龄');
}

为了提高效率简化繁琐的操作步骤,在这里我们使用了一种自定义语法来创建模型,暂且叫他“Model Describe Script”,简称“MDS”。 这种语法比编写Java实体、d.ts、建表语句或者图形化的操作方式效率更高。我们的目的是提高开发效率、减少开发成本,怎么高效就怎么做,而非所谓的“为了去代码化而去代码化”,相信大家已经看出来了。

创建一个接口

apis中新建一个PersionApi.js

export default {
    addAndListPersions: {
        description: '添加一个人员,并且列出所有的人员列表',
        execute() { 
            // 添加一个人员
            const persion = new Model.Persion();
            persion.persionName = '张三';
            persion.persionSex = 1;
            Dao.PersionDao.insert(persion);

            // 列出所有的人员列表
            return Dao.PersionDao.list(Where.emptyWhere());
        }
    }
}

这里的接口遵循ES6语法规范,可以通过JS的方式快速开发业务,并且不用担心安全问题,它实际上运行在服务器中而非在浏览器中运行,它和vue页面交互的过程实际上是经过封装的ajax的交互过程。

页面调用接口

修改MyPage.vue,调用上面的接口方法:

<template>
    <div>
        <h1 v-for="persion in persionList" v-text="persion.persionName + ':' + persion.persionSex"></h1>
    </div>
</template>

<script>
export default {
    name: 'MyPage',
    data() {
        return {
            persionList: []
        }
    },
    mounted(){
        this.$api.PersionApi.addAndListPersions().then(result => {
            this.persionList = result
        })
    }
}
</script>
<style lang="less" scoped>
</style>

此时,查看8080端口,每次刷新页面后,页面中都会增加一个“张三”

到此,简单的介绍完毕,大家先自行熟悉探索,上手并不难,详细的文档过段时间补充。