配置中心前端
Go to file
骑着蜗牛追导弹 3f5eb1d163 Signed-off-by: odboy <tianjun@odboy.cn> 2024-12-11 20:57:33 +08:00
public feat: init project 2024-12-03 19:28:38 +08:00
src Signed-off-by: odboy <tianjun@odboy.cn> 2024-12-11 20:57:33 +08:00
.editorconfig feat: init project 2024-12-03 19:28:38 +08:00
.env.development feat: 配置管理 2024-12-09 19:41:57 +08:00
.env.production feat: init project 2024-12-03 19:28:38 +08:00
.env.staging feat: init project 2024-12-03 19:28:38 +08:00
.eslintignore feat: init project 2024-12-03 19:28:38 +08:00
.eslintrc.js feat: init project 2024-12-03 19:28:38 +08:00
.gitignore feat: init project 2024-12-03 19:28:38 +08:00
.travis.yml feat: init project 2024-12-03 19:28:38 +08:00
LICENSE feat: init project 2024-12-03 19:28:38 +08:00
README.md Signed-off-by: odboy <tianjun@odboy.cn> 2024-12-11 20:57:33 +08:00
babel.config.js feat: init project 2024-12-03 19:28:38 +08:00
jest.config.js feat: init project 2024-12-03 19:28:38 +08:00
package.json feat: init project 2024-12-03 19:28:38 +08:00
plopfile.js feat: init project 2024-12-03 19:28:38 +08:00
postcss.config.js feat: init project 2024-12-03 19:28:38 +08:00
vue.config.js feat: 新增模块 2024-12-06 21:13:48 +08:00

README.md

Kenaito Config Front

项目简介

kenaito-config-front 是一个基于 Vue.js 和 Element UI 的前端项目主要用于管理和配置Kenaito Config系统。初始模板基于 vue-element-admin ,详细文档可参考 官方文档

依赖组件

名称 功能 官方文档
sortable.js 拖拽库 官方文档
vue-treeselect 下拉树组件 官方文档
wangeditor/editor 富文本编辑工具 官方文档
mavon-editor Markdown 编辑工具 官方文档
clipboard 一键复制 官方文档
vue-codemirror 代码高亮编辑器 官方文档
echarts 数据可视化图表 官方文档
file-saver 前端导出文件 官方文档
fuse.js 模糊搜索库 官方文档
jsencrypt RSA 加密和解密 官方文档
jszip ZIP 压缩库 官方文档
nprogress 页面加载进度条 官方文档
qs 查询字符串解析和序列化库 官方文档
vue-count-to 数字滚动插件 官方文档
vue-cropper 图片裁剪 官方文档
vue-image-crop-upload 头像裁剪上传 官方文档
vue-splitpane 可拖拽分割面板 官方文档
vuedraggable 拖拽插件 官方文档

快速开始

环境要求

推荐 node 版本12-16

安装依赖

# 安装依赖
npm install --registry https://registry.npmmirror.com

启动服务

# 启动服务 localhost:28001
npm run dev

# (或) 启动服务 localhost:28001
IDEA -> Current File -> Edit Configurations... -> Add New Configuration -> npm -> Script选dev -> Apply -> Ok

# 构建生产环境
npm run build:prod

默认密码

admin/123456

常见问题的解决方案

  • linux 系统在安装依赖的时候会出现 node-sass 无法安装的问题
    1. 单独安装npm install --unsafe-perm node-sass 
    2. 直接使用npm install --unsafe-perm
    

如何增加子系统模块

新增子系统请求路径

# .env.development
VUE_APP_{子系统编码}_BASE_API  = 'http://localhost:服务端口号'
VUE_APP_{子系统编码}_WS_API = 'ws://localhost:服务端口号'

# .env.staging
VUE_APP_{子系统编码}_BASE_API  = 'http://localhost:服务端口号'
VUE_APP_{子系统编码}_WS_API = 'ws://localhost:服务端口号'

# .env.production
VUE_APP_{子系统编码}_BASE_API  = 'https://kenaito-api.odboy.cn'
VUE_APP_{子系统编码}_WS_API = 'wss://kenaito-api.odboy.cn'

新增代理配置 -> vue.config.js

module.exports = {
  devServer: {
    proxy: {
      '/kenaito-{子系统编码}/': {
        target: process.env.VUE_APP_{子系统编码}_BASE_API,
        changeOrigin: true,
        pathRewrite:{
          '^/kenaito-{子系统编码}': '/api/{子系统编码}'
        }
      },
    }
  }
}

新增请求服务类 -> utils/request{子系统编码}.js

const service = axios.create({
  // 关键修改点 baseURL
  baseURL: process.env.NODE_ENV === 'production' ? process.env.VUE_APP_{子系统编码}_BASE_API: '/',
  timeout: Config.timeout
})

前端Service -> api写法1

# 所在路径
/src/api/{子系统编码}/{子模块编码}.js

# 子模块.js -> 可参考 src/api/config/productLine.js 的 queryPage 方法
import request from '@/utils/request{子系统编码}'
export function queryPage(data) {
  return request({
    // 这里的 'kenaito-{子系统编码}' 参考上面的 '新增代理配置'
    url: 'kenaito-{子系统编码}/{子模块编码}/queryPage',
    method: 'post',
    data: data
  })
}

前端Service -> api写法2

# 所在路径
/src/api/{子系统编码}/{子模块}.js

# 子模块.js -> 可参考 src/api/config/productLine.js 的 getTree 方法
import createService from '@/utils/requestMulti'
export function queryPage() {
  const service = createService('{子系统编码}')
  // 这里的 'kenaito-{子系统编码}' 参考上面的 '新增代理配置'
  return service({
    url: 'kenaito-{子系统编码}/{子模块编码}/queryPage',
    method: 'post'
  })
}

后端API请求路径 -> controller

// 可参考后端 kenaito-config-service/src/main/java/cn/odboy/rest/AppController.java 中的 queryPage 方法
@RestController
@RequestMapping("/api/{子系统编码}/{子模块编码}")
public class AppController {
  @PostMapping("/querySomething")
  public ResponseEntity<Object> querySomething(@RequestBody PageArgs<Object> args) {
    return new ResponseEntity<>(null, HttpStatus.OK);
  }
}

贡献指南

欢迎贡献代码!请遵循以下步骤:

  1. Fork 仓库
  2. 创建新分支: git checkout -b feature/your-feature
  3. 提交更改: git commit -m 'Add some feature'
  4. 推送分支: git push origin feature/your-feature
  5. 发起 Pull Request

许可证

本项目采用 MIT License 许可证。

联系我们

如果有任何问题或建议,请通过 GitHub Issues 联系我。