/*! 项目应用根路径 */ window.appRoot = (function (script) { return '/' + script.src.split('/').slice(3, -2).join('/') + '/'; })(document.querySelector('script[src][type=module]:last-child')); ;(async () => { const options = { moduleCache: { vue: Vue, less: less }, getFile(url) { if (!/^(https?:)?\/\//.test(url)) { 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 loadVueFile = (vuePath) => () => loadVue(vuePath); const router = VueRouter.createRouter({ routes: [], history: VueRouter.createWebHashHistory(), }); // 添加默认路由 router.addRoute({path: '/', redirect: '/static/template/pages/one.vue'}); // 路由前置处理 let loading = null; router.beforeEach(function (to, fr, next) { let name = to.fullPath.replace(/[.\/]+/g, '_'); if (router.hasRoute(name)) { console.log(''); console.log('load.open', to.fullPath) loading = ElementPlus.ElLoading.service({ lock: true, text: 'Loading', background: 'rgba(0, 0, 0, 0.3)', }); next(); } else { router.addRoute({name: name, path: to.fullPath, component: loadVueFile(to.fullPath)}); next({name: name}); } }); // 动态注销路由 router.afterEach(function (to) { let name = to.fullPath.replace(/[.\/]+/g, '_'); if (router.hasRoute(name)) { router.removeRoute(name) } if (loading) { console.log('load.done') loading.close(); loading = null; } }); // window.$think = Vue.createApp({ // // name: 'ThinkAdmin', // components: { // layout: await loadVue('./static/template/layout.vue'), // } // }); const app = Vue.createApp(Vue.defineAsyncComponent(function () { return loadVue('/static/template/layout.vue'); })); // 全局字体文件 const icons = await loadVue("/static/plugs/core/vue.element.icons.js"); for (let i in icons) app.component(i, icons[i]); app.use(router).use(ElementPlus).mount(document.body); })().catch(function (ex) { console.error(ex); });