main.js 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. // The Vue build version to load with the `import` command
  2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
  3. import './public-path.js';
  4. import { createApp } from 'vue';
  5. import { createRouter, createWebHashHistory } from 'vue-router';
  6. import { createI18n } from 'vue-i18n';
  7. import App from './App.vue';
  8. import routes from './router/index.js';
  9. import PcClientComponent from 'pc-component-v3';
  10. import VueDOMPurifyHTML from 'vue-dompurify-html';
  11. import Antd from 'ant-design-vue';
  12. // bug fixed by jack
  13. // 在加载 css 的时候 font 不能被正确的加载
  14. import './assets/summernote.css';
  15. import 'ant-design-vue/dist/antd.css';
  16. let instance = null;
  17. let i18n = createI18n({
  18. locale: 'zh-CN',
  19. messages: {
  20. 'zh-CN': require('./lang/zh-CN.js'),
  21. 'en-US': require('./lang/en-US.js'),
  22. },
  23. });
  24. let router = createRouter({
  25. history: createWebHashHistory(),
  26. routes: routes,
  27. });
  28. function render(props = {}) {
  29. const { container } = props;
  30. instance = createApp(App);
  31. instance.use(i18n);
  32. instance.use(Antd);
  33. instance.use(router);
  34. instance.use(PcClientComponent);
  35. instance.use(VueDOMPurifyHTML);
  36. instance.mount(container ? container.querySelector('#app-client-trace') : '#app-client-trace');
  37. }
  38. // 独立运行时
  39. if (!window.__POWERED_BY_QIANKUN__) {
  40. render();
  41. }
  42. /**
  43. * bootstrap 只会在微应用初始化的时候调用一次,下次微应用重新进入时会直接调用 mount 钩子,不会再重复触发 bootstrap。
  44. * 通常我们可以在这里做一些全局变量的初始化,比如不会在 unmount 阶段被销毁的应用级别的缓存等。
  45. */
  46. export async function bootstrap() {
  47. console.log('[client-trace-v3] bootstraped');
  48. }
  49. /**
  50. * 应用每次进入都会调用 mount 方法,通常我们在这里触发应用的渲染方法
  51. */
  52. export async function mount(props) {
  53. console.log('[client-trace-v3] props from main framework', props);
  54. render(props);
  55. instance.config.globalProperties.$onGlobalStateChange = props.onGlobalStateChange;
  56. instance.config.globalProperties.$setGlobalState = props.setGlobalState;
  57. }
  58. /**
  59. * 应用每次 切出/卸载 会调用的方法,通常在这里我们会卸载微应用的应用实例
  60. */
  61. export async function unmount() {
  62. instance.unmount();
  63. instance._container.innerHTML = '';
  64. instance = null;
  65. }