简介
StartCMS是一个基于ThinkPHP6.0+、ElementUI、MicroApp的极速微应用开发框架
前端不限技术栈,支持Vue2、Vue3、Vite、React、Rangular...
后端不限制语言,支持PHP、Java、Node、Python、Go、C#...
一、本文接续上一篇文章,介绍如何使用startCMS进行应用开发
如果您对StartCMS有疑惑,建议先阅读下方文章来了解更多。阅读本文前建议先阅读下面两篇文章,否则可能会看不明白一些操作。
微前端框架StartCMS, 一个基于微前端架构的极速微应用开发框架,开源框架
微前端框架StartCMS,如何启动框架,startCMS启动教程
二、框架目录
如果您没有看过官方文档 STARTCMS,请看下方目录介绍,详情可进入官方文档查看。
www WEB部署目录
├─app 应用目录
│ ├─app1 应用1
│ ├─app2 应用2
│ ├─app3...
├─base 前端基座工程(可移动到任意地方进行前后端分离开发)
├─config 系统配置目录
├─core 系统核心目录
├─data 数据存储目录
├─extend 扩展类库目录
├─runtime 应用的运行时目录(可写,可定制)
├─vendor Composer类库目录
├─web 前端基座目录(由基座工程目录编译生成)
├─.env.default 环境示例文件
├─.gitignore Git配置文件
├─.htaccess Apache配置文件
├─composer.json Composer配置文件
├─deploy.sh 自动化部署脚本
├─index.php 系统入口文件
├─start 命令行入口
二、如果基于PHP开发
由于startCMS框架本身基于PHP开发,如果您也刚好使用PHP开发,那您可以使用命令行生成一个app应用。生成命令为
php start make:app 应用名
执行前app目录中只有.gitignore文件,执行 php start make:app test 后,app目录会生成test应用。如下图所示。
如图所示,test应用中存在3个目录以及app.json,文件controller,model,service这里不做说明,主要讲解app.json,下面是app.json配置信息
{
"app": "", // 应用标识(默认缺省,安装时自动识别)
"app_title": "", // 应用名称(默认缺省,安装时自动识别)
"group": "站点配置", // 配置分组(可选)
"title": "站点名称", // 配置名称
"type": "input", // 输入类型
"field": "title", // 字段名称(确保同一应用内唯一)
"value": "StartCMS", // 字段值(可选)
"options": [], // 配置选项(可选)
"validate": [], // 验证规则(可选)
"props": {}, // 配置属性(可选)
"default": "", // 默认值(可选)
"remark": "", // 备注(可选)
"locking": 0, // 是否锁定(禁止编辑更新)
"protected": 0 // 是否保护(前端无法获取)
}
下图是test自动生成的配置信息
启动框架进入系统,不知道怎么启动的,建议先看下方文章
微前端框架StartCMS,如何启动框架,startCMS启动教程
启动系统后,点击打开右上角应用配置
如果app中没有应用,那么此时应用中心为空。
创建test应用后,表格中会出现test应用的信息,app.json中可以修改test应用信息,详细请查看官方文档。
到这一步,后端工作基本准备完成。点击启用安装应用。安装成功后刷新页面
刷新后安装的应用就会出现在左侧侧边栏了
由于缺少前端工程,当前的test应用点击是没有内容的,以vue2示例,来介绍如何构建前端工程。打开终端,进入test应用,使用命令vue create vue2创建vue2模板
创建完成后修改vue.config.js,由于此时框架启动在8080端口,且test应用也在框架内部,并没有启动其他的服务器,所以配置代理以及修改静态资源路径如下,如果应用需要请求资源是其他服务器,更改代理即可。
module.exports = defineConfig({
publicPath: '/app/test/view/',
transpileDependencies: true,
devServer: {
port: port,
open: false,
overlay: {
warnings: false,
errors: true
},
proxy: {
[process.env.VUE_APP_BASE_API]: {
target: 'http://localhost:8080',
changeOrigin: true,
pathRewrite: {
['^' + process.env.VUE_APP_BASE_API]: '/'
}
}
},
headers: {
'Access-Control-Allow-Origin': '*'
}
}
})
修改完成后使用 npm run build 打包,这时会生成dist文件夹,将dist文件夹重命名为view,移动至test目录下,或者手动创建view目录,将dist下所有文件复制或移动到view中。
这时我们的静态资源,也就是 index.html 已经准备完成了,但这个时候,点击test应用如下
错误的原因是因为访问 http://localhost:8080/web/test 时,服务器并没有做出回应,打开controller目录中的index.php,加入下方代码来渲染 index.html
刷新页面,就可以看到vue的模板页面了
实际上每一个应用的核心就是controller,model,service,view,app.json这些文件
view即打包后的目录也是前端代码,app.json是应用配置,controller,model,service构成服务器响应前端。这些加起来也就构成了一个独立的应用。
三、如果后端使用java,python或其他语言
- 如果后端已经上线服务器,那么只需要在前端配置代理与静态资源路径,在后端那边渲染前端html页面即可,后端的代码也可以不放在框架内部。
- 如果是本地开发,并未上线,以java为例,无论您的后端代码是否在框架应用内,您只需要启动您的java后端,开启一个端口,然后将这个端口替换掉前端 vue.config.js 中的8080即可,前万不要忘记配置静态资源路径,千万不要忘记渲染 index.html,并且不需要加多余路径,渲染 /index 即可,框架基座会自动找到应用下的view目录。
四、总结
startCMS框架的核心思想就是微前端,微应用,开发者能在同一个项目中使用不同语言,后端可以同时用java,python,PHP写,前端也能同时用vue,react,angular写。
比如一个商城系统,有商品模块,订单模块。那么我们可以把这两个模块做成应用,假如商品模块使用vue更容易,而订单模块使用react更好,按以前正常框架是无法实现的。而startCMS可以实现这一点,并且,如果其中一个模块需要升级某个依赖包,而升级后又会对另一个模块产生影响,这时使用startCMS完全不用担心。
startCMS主要解决以下问题:
1、随着项目迭代前端工程越来越庞大,难以维护 => 项目应用化,只需要维护应用。
2、跨团队或跨部门协作开发项目导致效率低下且受基础框架技术限制 => 应用化之后,每个应用都可以使用不同语言,不同框架。
3、不同业务模块需要使用不一样的依赖,随着时间推移依赖冲突严重且不支持增量升级 => 应用之间相互独立,互不依赖,升级模块时不用担心影响其他功能。
4、市场现有多模块系统,后端虽然做到了模块化并前后端分离,但前端工程本质上依然属于单体架构。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。