102 lines
4.0 KiB
JavaScript
Raw Normal View History

2025-04-02 18:29:07 +08:00
/*
* 项目启动入口方法
*
* @Author: 1024创新实验室-主任卓大
* @Date: 2022-09-06 20:59:23
* @Wechat: zhuda1024
* @Email: lab1024@163.com
* @Copyright 1024创新实验室 https://1024lab.net Since 2012
*/
import { createApp } from 'vue';
import Antd, { message } from 'ant-design-vue';
import * as antIcons from '@ant-design/icons-vue';
import lodash from 'lodash';
import JsonViewer from 'vue3-json-viewer';
import 'vue3-json-viewer/dist/index.css';
import App from './App.vue';
import { smartSentry } from '/@/lib/smart-sentry';
import { loginApi } from '/@/api/system/login-api';
import constantsInfo from '/@/constants/index';
import { privilegeDirective } from '/@/directives/privilege';
import i18n from '/@/i18n/index';
import privilegePlugin from '/@/plugins/privilege-plugin';
import smartEnumPlugin from '/@/plugins/smart-enums-plugin';
import { buildRoutes, router } from '/@/router';
import { store } from '/@/store';
import { useUserStore } from '/@/store/modules/system/user';
import 'ant-design-vue/dist/reset.css';
import 'vue3-tabs-chrome/dist/vue3-tabs-chrome.css';
import '/@/theme/index.less';
import { localRead } from '/@/utils/local-util.js';
import LocalStorageKeyConst from '/@/constants/local-storage-key-const.js';
import '/@/components/scrollbar/css/scrollbar.css';
import AScrollbar from '/@/components/scrollbar';
2025-04-30 18:37:55 +08:00
import 'video.js/dist/video-js.css';
2025-04-02 18:29:07 +08:00
/*
* -------------------- 着重 解释说明下main.js的初始化逻辑 begin --------------------
*
* 1在main.js里很多框架都是 直接调用初始化的vue方法创建vue实例然后挂载路由router状态管理store等等但是关于router这块是有问题的
* 2因为现在大部分路由都是从后端接口返回的如若直接初始化挂载路由这时前端还没有从后端请求路由的数据所以只能写到路由拦截器里这样很绕很不清晰
* 正确的做法流程应该是
* 2.1如果存在登录信息则先ajax请求用户的所有路由然后加载再去创建vue实例和挂载路由
* 2.2如果不存在路由信息则创建vue实例和挂载路由此时的路由应该只有login页面因为用户拥有哪些路由是登录之后才知道的
* 3以上在main.js里两个方法一个是 获取登录信息getLoginInfo另一个初始化vue: initVue在最下的if操作里
*
* -------------------- 着重 解释说明下main.js的初始化逻辑 end --------------------
*/
/**
* 获取用户信息和用户权限对应的路由构建动态路由
*/
async function getLoginInfo() {
try {
//获取登录用户信息
const res = await loginApi.getLoginInfo();
//构建系统的路由
let menuRouterList = res.data.menuList.filter((e) => e.path || e.frameUrl);
2025-07-18 16:45:43 +08:00
if (res.data.level == '4') {
menuRouterList = menuRouterList.filter((e) => e.path != '/organize/list');
}
2025-04-02 18:29:07 +08:00
buildRoutes(menuRouterList);
initVue();
//更新用户信息到pinia
useUserStore().setUserLoginInfo(res.data);
} catch (e) {
message.error(e.data ? e.data.msg : e.message);
smartSentry.captureError(e);
initVue();
}
}
function initVue() {
let vueApp = createApp(App);
let app = vueApp.use(router).use(store).use(i18n).use(Antd).use(smartEnumPlugin, constantsInfo).use(privilegePlugin).use(JsonViewer).use(AScrollbar);
//注入权限
app.directive('privilege', {
mounted(el, binding) {
privilegeDirective(el, binding);
},
});
// 注册图标组件
Object.keys(antIcons).forEach((key) => {
app.component(key, antIcons[key]);
});
//全局
app.config.globalProperties.$antIcons = antIcons;
app.config.globalProperties.$lodash = lodash;
//挂载
app.mount('#app');
}
//不需要获取用户信息、用户菜单、用户菜单动态路由直接初始化vue即可
let token = localRead(LocalStorageKeyConst.USER_TOKEN);
if (!token) {
initVue();
} else {
getLoginInfo();
}