litian
2024-11-20 7a4a5658ba89afda9e89b31e92a40ad7658fd29e
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
import './assets/main.css'
 
import { createApp } from 'vue'
import pinia from '@/store/index'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import App from './App.vue'
import router from './router'
import * as ElementPlusIconsVue from '@element-plus/icons-vue'
import toolClass from '@/assets/js/toolClass'
import MG from '@/assets/js/middleGround/WebMiddleGroundApi.js'
import './child.ts'
import { loginCtx } from '@/assets/js/config.ts'
 
const handleGetToken = () => {
  return localStorage.getItem('token')
}
 
// 路由执行之前的一些操作
router.beforeEach((to, from, next) => {
  const isInternalLink = from.fullPath.includes('/testBookReader')
  if (isInternalLink) {
    sessionStorage.removeItem('loginCtx')
  } else {
    sessionStorage.setItem('loginCtx', loginCtx)
  }
 
  next()
  // if (handleGetToken()) {
  //   // 是否是登录页面,直接到首页
  //   if (to.path === '/login') {
  //     next({ path: '/home', query: { bookId: localStorage.getItem('bookId') } })
  //   } else {
  //     // 如果不是登录页面,跳转到目标的页面
  //     next()
  //   }
  // } else {
  //   // 没有token
  //   if (!to.meta || !to.meta.auth) {
  //     // 在免登录白名单,直接进入
  //     next()
  //   } else {
  //     next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
  //   }
  // }
})
 
// qiankun主应用与微应用通讯
// import { initGlobalState, type MicroAppStateActions } from 'qiankun'
// import state from './qiankunState/state'
 
// state.bb = (data) => {
//   console.log(data);
// }
 
// 初始化 state
// const actions: any = initGlobalState(state)
 
// 监听state变化
// actions.onGlobalStateChange((state: any, prev: any) => {
//   // state: 变更后的状态; prev 变更前的状态
//   console.log("父层change:",state, prev)
// })
// 设置state的值
// actions.setGlobalState(state)
 
// console.log(actions,"actions");
 
// app.provide('qiankunActions', actions)
// window.qiankunActions = actions
 
// 移除当前应用的状态监听,微应用 umount 时会默认调用
// actions.offGlobalStateChange()
 
const app = createApp(App)
 
app.provide('toolClass', toolClass)
app.provide('MG', MG)
app.use(router)
app.use(ElementPlus)
app.use(pinia)
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component)
}
 
app.mount('#parentApp')