main.js 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import './public-path.js';
  2. import { createApp } from 'vue/dist/vue.esm-bundler.js';
  3. import Antd from 'ant-design-vue';
  4. import App from './App.vue';
  5. import { createRouter, createWebHashHistory } from 'vue-router';
  6. import * as PcComponentV3 from 'pc-component-v3';
  7. import 'pc-component-v3/dist/pc-component-v3.css';
  8. import 'ant-design-vue/dist/reset.css';
  9. import './assets/main.css';
  10. import routes from './router/routes.js';
  11. import $ from 'jquery';
  12. window.$ = $;
  13. window.jQuery = $;
  14. window.PcComponentV3 = PcComponentV3;
  15. let instance = null;
  16. const router = createRouter({
  17. // 4. 内部提供了 history 模式的实现。为了简单起见,我们在这里使用 hash 模式。
  18. history: createWebHashHistory(),
  19. routes, // `routes: routes` 的缩写
  20. });
  21. function render(props = {}) {
  22. const { container } = props;
  23. instance = createApp(App);
  24. instance.use(Antd);
  25. instance.use(PcComponentV3);
  26. instance.use(router);
  27. instance.mount(container ? container.querySelector('#app') : '#app');
  28. }
  29. // 独立运行时
  30. if (!window.__POWERED_BY_QIANKUN__) {
  31. render();
  32. }
  33. /**
  34. * bootstrap 只会在微应用初始化的时候调用一次,下次微应用重新进入时会直接调用 mount 钩子,不会再重复触发 bootstrap。
  35. * 通常我们可以在这里做一些全局变量的初始化,比如不会在 unmount 阶段被销毁的应用级别的缓存等。
  36. */
  37. export async function bootstrap() {
  38. console.log('[client-role-v3] bootstraped');
  39. }
  40. /**
  41. * 应用每次进入都会调用 mount 方法,通常我们在这里触发应用的渲染方法
  42. */
  43. export async function mount(props) {
  44. console.log('[client-role-v3] props from main framework', props);
  45. render(props);
  46. instance.config.globalProperties.$onGlobalStateChange = props.onGlobalStateChange;
  47. instance.config.globalProperties.$setGlobalState = props.setGlobalState;
  48. }
  49. /**
  50. * 应用每次 切出/卸载 会调用的方法,通常在这里我们会卸载微应用的应用实例
  51. */
  52. export async function unmount() {
  53. instance.unmount();
  54. instance._container.innerHTML = '';
  55. instance = null;
  56. }