vite.config.js配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import { defineConfig, loadEnv } from 'vite'
import path from 'path'
import createVitePlugins from './vite/plugins'
// https://vitejs.dev/config/
export default defineConfig(({ mode, command }) => {
const env = loadEnv(mode, process.cwd())
const { VITE_APP_ENV } = env
return {
// 部署生产环境和开发环境下的URL。
// 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上
// 例如 https://www.ruoyi.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.ruoyi.vip/admin/,则设置 baseUrl 为 /admin/。
// base: VITE_APP_ENV === 'production' ? '/' : '/',

// 构建时输出目录 前端访问路由地址
base: VITE_APP_ENV === 'production' ? '/' : '/',
build: {
outDir: '../ruoyi-ui-template', // 构建时输出目录
assetsDir: 'static', // 放置生成的静态资源的目录
},
plugins: createVitePlugins(env, command === 'build'),
resolve: {
// https://cn.vitejs.dev/config/#resolve-alias
alias: {
// 设置路径
'~': path.resolve(__dirname, './'),
// 设置别名
'@': path.resolve(__dirname, './src')
},
// https://cn.vitejs.dev/config/#resolve-extensions
extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']
},
// vite 相关配置
server: {
port: 8321,
host: true,
open: true,
cors: false,
proxy: {
// https://cn.vitejs.dev/config/#server-proxy
'/dev-api': {
target: 'http://localhost:8080',
changeOrigin: true,
rewrite: (p) => p.replace(/^\/dev-api/, '')
}
}
},
//fix:error:stdin>:7356:1: warning: "@charset" must be the first rule in the file
css: {
postcss: {
plugins: [
{
postcssPlugin: 'internal:charset-removal',
AtRule: {
charset: (atRule) => {
if (atRule.name === 'charset') {
atRule.remove();
}
}
}
}
]
}
}
}
})

静态路由配置

系统管理->菜单管理中新增菜单.配置路由地址,路由地址为访问地址,配置组件地址,组件地址为组件路径.
配置好后不需要在项目的router中配置,直接访问路由地址即可.

  • 目录为默认显示
  • 菜单可以控制权限显示
  • 按钮可以控制权限显示

创建好菜单后,在角色管理->角色编辑中配置菜单权限.

动态路由地址

如果想创建一个页面,这个页面不在菜单中,是通过其他页面点击进入的,并且传递参数,则需要添加动态路由地址.
在router/index.js中配置动态路由地址
例子:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// /move/dataInput-detail/detail/1?id=1
{
path: '/move/dataInput-detail', // 此处父层地址为move/dataInput(在后台菜单管理中配置会自动生成) 不能配置相同的路由地址
component: Layout,// 固定 不要动
hidden: true, // 侧边栏是否显示 已测试没有效果
permissions: ['move:dataInput:edit'], // 不配置权限会报错 404 格式:(模块:功能:操作)
children: [
{
path: 'detail/:id(\\d+)',// detail为url中的一个参数 可以修改也可以不填写(:id(\\d+))
component: () => import('@/views/move/dataInput/detail'), // 组件路径
name: 'DataInputDetail', // 组件名称
meta: { title: '数据录入详情', activeMenu: '/move/dataInput' } // 组件标题, 当前组件显示的时候左侧菜单应该默认选中哪个菜单项
}
]
},