|
|
2 zile în urmă | |
|---|---|---|
| .. | ||
| .vscode | 3 săptămâni în urmă | |
| cacp | 3 săptămâni în urmă | |
| public | 3 săptămâni în urmă | |
| src | 2 zile în urmă | |
| .gitignore | 3 săptămâni în urmă | |
| .npmrc | 3 săptămâni în urmă | |
| .prettierrc.json | 3 săptămâni în urmă | |
| Dockerfile | 3 săptămâni în urmă | |
| Dockerfile-arm | 3 săptămâni în urmă | |
| README.md | 3 săptămâni în urmă | |
| env.d.ts | 3 săptămâni în urmă | |
| eslint.config.js | 3 săptămâni în urmă | |
| index.html | 6 zile în urmă | |
| nginx.conf | 3 săptămâni în urmă | |
| node_version | 3 săptămâni în urmă | |
| package.json | 6 zile în urmă | |
| tsconfig.app.json | 3 săptămâni în urmă | |
| tsconfig.json | 3 săptămâni în urmă | |
| tsconfig.node.json | 3 săptămâni în urmă | |
| vite.config.ts | 3 săptămâni în urmă | |
|── public // 公共资源
│ ├── config.js // 项目部署后根据实际地址修改配置,本地开发无需关注
│ ├── favicon.ico // 项目favicon小图标
├── src // 源代码
│ ├── apis // 所有 HTTP 请求
│ │ ├── user.ts //(根据业务模块命名,和 /views/* 一一对应)
│ │ ├── authority.ts // 根据用户获取角色与权限
│ │ ├── frame.ts // 获取用户信息
│ ├── assets // 图片样式等静态资源
| ├── components // 公共组件
| ├── directives // 通用指令封装
│ │ ├── index.ts // directives文件整合入口
│ │ ├── permission.ts // 校验页面功能权限方法
| ├── hooks // 公共方法封装
| ├── plugins // 插件配置
│ │ ├── index.ts // 插件文件整合入口
│ │ ├── icon.ts // cacp/svg-icons图标全局注册
│ ├── router // 路由
│ │ ├── app-router.ts // 根据项目大小调整,项目模块少可以集中在app-router.ts里面配置,反之(根据业务模块命名,和 /views/* 一一对应)
│ │ ├── index.ts // 路由入口
│ ├── stores // 全局 store 管理
│ │ ├── index.ts // store文件整合入口
│ │ ├── core.ts // 获取用户信息
│ │ ├── pinia.ts // pinia配置
│ ├── types // TS类型定义
│ │ ├── user.ts //(根据业务模块命名,和 /views/* 一一对应)
│ ├── utils // 全局公用方法
│ │ ├── authhelper.ts // 401报错消息发送给门户框架,以及框架处理
│ │ ├── frame.ts // 监听门户发送过来的用户信息消息,以及监听cookie消息
│ │ ├── http.ts // 调用不同应用接口服务,全url访问
│ │ ├── request.ts // 全局 http 请求方法封装,调用相同应用接口服务,相对路径
│ ├── views // 页面视图
│ │ ├── user // 响应路由切换的 vue 组件(根据业务模块命名,和 /apis/* 一一对应)
│ │ ├── ErrorView // 错误页面
│ │ ├── HomeView // 首页
│ ├── App.vue // 入口vue
│ ├── main.ts // vue 入口加载组件初始化等
│ ├── config.ts // 自定义配置,本地开发与后台接口联调参数配置
├── vite.config.ts // vite配置
├── .gitignore // 文件提交忽略配置
├── .prettierrc.json // 代码格式化配置
├── nginx.conf // ng配置,部署后生效
├── node_version // node版本设置,部署后生效
├── Dockerfile // 项目部署X86环境Dockerfile配置,部署后生效
├── Dockerfile-arm // 项目部署arm环境Dockerfile配置,部署后生效
└── package.json // 包配置
└── package-lock.json // 包下载地址
127.0.0.1 local.系统缩写-模块缩写.dev-nb.com,映射域名的二级域名需要与前端框架保持一致;根据项目实际需求开发修改以下文件:
src/apis/*src/assets/*src/components/*src/directives/*src/hooks/*src/plugins/*src/router/*src/stores/*src/types/*src/utils/*src/views/*src/App.vueconfig.ts根据业务需求在/src/views文件夹下创建新的业务文件夹,根据业务模块添加user文件夹,相关功能页面全部写在该文件夹下,目录的层级不要太深,添加src/views/user/UserInfoView.vue
<template>
<div>
<h3>人员信息</h3>
<el-table :data="personArr">
<el-table-column label="编号" prop="id">
</el-table-column>
<el-table-column label="姓名" prop="name">
</el-table-column>
<el-table-column label="关区号" prop="customsCode">
</el-table-column>
</el-table>
</div>
</template>
<script setup lang="ts">
import { reactive } from 'vue'
import type { User } from '@/types/user'
const personArr = reactive<Array<User>>([
{ id: '1', name: '张三', customsCode: '4200', },
{ id: '2', name: '李四', customsCode: '5200', },
{ id: '3', name: '王五', customsCode: '0100', },
])
</script>
<style scoped lang="less">
</style>
增加路由模块src/router/app-router.ts
import type { RouteRecordRaw } from 'vue-router'
const routers: Array<RouteRecordRaw> = [
{
path: '/user-info',
name: 'userInfo',
component: () => import('@/views/user/UserInfoView.vue'),
meta: {
title: '用户信息',
anonymous: true,
keepAlive: true
}
},
]
export default routers
添加新页面路由到src/router/index.ts中。
路由路径要有描述性和包含关键词,路由长度越短越好,不要有太多参数。
路由的路径要全小写字母,连词符要用中划线(-), 不要使用下划线(_)。
import { createRouter, createWebHashHistory, RouterView } from 'vue-router'
import appRouter from './app-router'
const router = createRouter({
history: createWebHashHistory(),
routes: [
{
path: '/',
component: RouterView,
children: [
{
path: '/',
redirect: '/home'
},
{
path: 'home',
name: 'home',
component: () => import('@/views/HomeView.vue'),
meta: {
title: '首页',
anonymous: true,
keepAlive: true
}
},
...appRouter
]
}
]
})
// ...
向侧边栏目录添加新页面目录信息src/App.vue,侧边栏导航只在开发环境展示;
// ...
<router-link to="/user-info">
<el-menu-item index="UserInfo">
<el-icon><House /></el-icon>
<span>用户信息</span>
</el-menu-item>
</router-link>
// ...
用户模块效果,用户列表页面
/src/apis下创建同views中一样的同名文件/src/apis/user.ts脚手架中封装了请求工具request(/src/utils/request.ts)和http(/src/utils/http.ts),采用axios的请求,增加了请求拦截和响应拦截,如果需要在请求前增加统一参数,或者响应时对数据统一处理可在此修改;
备注:request.ts调用相同应用接口服务,使用相对路径,http.ts调用不同应用接口服务,全url访问,使用绝对路径,使用场景前端与后端不是同一个服务;
import type { AxiosResponse } from 'axios'
import request from '@/utils/request'
import type { Result } from '@cacp/ui'
import type { Custom } from '@/types/user'
const contextPath = '/后端服务名'
// 关区翻译
export async function queryCustom(query: Array<String>): Promise<Result<Array<Custom>>> {
const res: AxiosResponse<Result<Array<Custom>>> = await request.post(`${contextPath}/customs/query-customs`, query)
return res.data
}
在业务页面添加api请求数据/src/views/user/UserInfoView.vue
<template>
<div>
<h3>人员信息</h3>
<el-table :data="personArr">
<el-table-column label="编号" prop="id">
</el-table-column>
<el-table-column label="姓名" prop="name">
</el-table-column>
<el-table-column label="关区号" prop="customsCode">
</el-table-column>
<el-table-column label="关区" prop="customsName">
</el-table-column>
</el-table>
</div>
</template>
<script setup lang="ts">
import { reactive } from 'vue'
import type { User, Custom } from '@/types/user'
import type { Result } from '@cacp/ui'
import * as userInfoApis from '@/apis/user'
const personArr = reactive<Array<User>>([
{ id: '1', name: '张三', customsCode: '4200', },
{ id: '2', name: '李四', customsCode: '5200', },
{ id: '3', name: '王五', customsCode: '0100', },
])
queryCustomInfo()
async function queryCustomInfo(): Promise<void> {
const customCodes: Array<string> = []
for (const preson of personArr) {
customCodes.push(preson.customsCode)
}
const res: Result<Array<Custom>> = await userInfoApis.queryCustom(customCodes)
if (res.code === SuccessResultCode) {
for (const preson of personArr) {
for (const custom of res.data) {
if (preson.customsCode === custom.code) {
preson.customsName = custom.name
}
}
}
}
}
</script>
<style scoped lang="less">
</style>
nginx.conf 进行配置,保持默认即可,配置代理到 API网关 上;配置代理与本地后端交互(src/config.ts),备注:最新后端脚手架已解决跨域,可以直接在/src/config.ts中配置后台服务地址;
// ...
import type { CacpConfig } from '@cacp/ui'
// 本地开发后台接口地址配置,线上忽略此配置,线上部署配置参考public/config.js文件
const devConfig: CacpConfig = {
SERVICE_ID: '{{service_id}}', //应用服务Id,同CACPAppCode
SERVICE_NAME: '{{service_name}}', //应用服务名
SERVICE_API: 'http://10.200.73.47:18001', // 本地开发应用服务后端ip地址,根据实际开发修改地址
SERVICE_PAGESIZE: 20, // 本应用表格分页缺省大小
SERVICE_TIMEOUT: 300000, //后端API超时请求超时时间
FRAME_API: '/api/cacp-frame-service', //统一入口后端服务地址;
CACP_DEMO_API: '/api/cacp-demo-service', // 为了展示user样例页面使用,不用样例页面时可以删除
NEED_USER_AUTHORITY: true, //前端路由和控件是否需要鉴权
AUTH_MODE: 'Cookie', // 认证方式,JWT或者Cookie
CUSTOMS_CODE: '0000', // 所属海关代码
PROFILE: 'DEV' // 运行环境 DEV、PROD
}
const $config = (window as any).$config as CacpConfig
const { DEV } = import.meta.env
export default DEV ? devConfig : $config
// ...
配置代理与本地后端交互(vite.config.ts),备注:涉及跨域使用此方法
// ...
server: {
port: 8080,
// 是否自动在浏览器打开
open: true,
proxy: {
// 将'localhost:3000/api/服务名/接口名'代理到'http://10.200.**.**:24001/接口名'
'/api/后端服务名': {
target: 'http://10.200.**.**:24001/', // 对应本地后台服务的ip+端口
changeOrigin: true, // 如果接口跨域,需要进行这个参数配置
rewrite: (path) => path.replace('/api/后端服务名', '') // 来重写地址,将前缀 '/api' 转为 '/'。
}
}
}
// ...
代码中使用console.log('res', res)
// ...
queryCustomInfo()
async function queryCustomInfo(): Promise<void> {
const customCodes: Array<string> = []
for (const preson of personArr) {
customCodes.push(preson.customsCode)
}
const res: Result<Array<Custom>> = await userInfoApis.queryCustom(customCodes)
console.log('res', res)
if (res.code === SuccessResultCode) {
for (const preson of personArr) {
for (const custom of res.data) {
if (preson.customsCode === custom.code) {
preson.customsName = custom.name
}
}
}
}
}
// ...
代码中使用debugger (不推荐),多人协同开发时,误提交debugger影响他人开发;