;(async () => { /*! 项目应用根路径 */ window.appRoot = (function (script) { return '/' + script.src.split('/').slice(3, -2).join('/') + '/'; })(document.querySelector('script[src*="app.js"]')); /*! 模块加载请求处理 */ const options = { moduleCache: { vue: Vue, less: less }, getFile(url) { if (!(/^(https?:)?\/\//)) { url = (appRoot + url).replace(/\/+.?\/+/g, '/'); } return fetch(url).then(res => { if (res.ok) { return {getContentData: binary => binary ? res.arrayBuffer() : res.text()}; } else if (res.status === 404) { return ``; } else { throw Object.assign(new Error(url + ' ' + res.statusText), {res}); } }); }, addStyle(style) { const before = document.head.getElementsByTagName('style')[0] || null; const object = Object.assign(document.createElement('style'), {textContent: style}); document.head.insertBefore(object, before); }, }; const {loadModule} = window['vue3-sfc-loader']; const loadVue = (vuePath) => loadModule(vuePath, options); const router = VueRouter.createRouter({ routes: [], history: VueRouter.createWebHashHistory(), }); // 创建后台主路由 router.addRoute({ name: 'layout', path: '/', component: () => { return loadVue('/static/template/layout.vue'); }, children: [{path: '/', redirect: '/static/template/login.vue'},] }); // 动态注销路由 router.afterEach(function (to) { let name = to.fullPath.replace(/[.\/]+/g, '_'); if (router.hasRoute(name)) router.removeRoute(name) if (loading) loading = loading.close(), null; document.querySelectorAll('.think-page-loader').forEach(function (el) { el.style.display = 'none'; }); }); // 动态注册路由 let loading = null; router.beforeEach(function (to, fr, next) { let name = to.fullPath.replace(/[.\/]+/g, '_'); if (router.hasRoute(name)) { console.log('PAGE-LOADING:', to.fullPath) loading = ElementPlus.ElLoading.service({ lock: true, text: 'Loading', background: 'rgba(0, 0, 0, 0.3)', }); next(); } else { // 删除页面缓存 delete options.moduleCache[to.fullPath]; // 登录页面处理 if (to.fullPath.indexOf('/login.vue') > -1) { router.addRoute({name: name, path: to.fullPath, component: () => loadVue(to.fullPath)}) } else { // 动态注册路由并触发新路由 router.addRoute('layout', {name: name, path: to.fullPath, component: () => loadVue(to.fullPath)}); } next({name: name}); } }); // 创建 Vue 应用 const app = Vue.createApp({}); // 定义全局缓存,加载字体组件 app.cache = {loadOpt: options, loadVue: loadVue, icons: ElementPlusIconsVue}; for (let i in app.cache.icons) app.component(i, app.cache.icons[i]); // 注册 getApp 获取应用 window.getApp = () => app; // 绑定 data-route 路由处理 document.body.addEventListener('click', function (event) { let target = event.target, attrname = 'data-router'; while (target && !target.hasAttribute(attrname)) { target = target.parentElement; if (target && target.hasAttribute(attrname)) break; } if (target && target.hasAttribute(attrname)) { event.stopPropagation(); router.push(target.dataset.route); } }); // 应用组件及路由 app.use(ElementPlus).use(router).mount(document.body); })().catch(ex => console.error(ex));