ventModal.vue 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <template>
  2. <div style="position: absolute; width: 100%; height: 100%">
  3. <a-spin class="loading-box" size="large" :spinning="loading" tip="正在加载,请稍等。。。" />
  4. </div>
  5. <div id="micro-vent-3dModal"></div>
  6. </template>
  7. <script lang="ts">
  8. import { ref, onMounted, onBeforeUnmount, defineComponent, unref } from 'vue';
  9. import { unmountMicroApps, mountMicroApp, activeApps } from '/@/qiankun';
  10. import { resetMicroContentWH } from '/@/utils/domUtils';
  11. import { useRouter } from 'vue-router';
  12. export default defineComponent({
  13. name: 'VentModel',
  14. setup() {
  15. const { currentRoute } = useRouter();
  16. const loading = ref(true);
  17. onMounted(() => {
  18. // 判断子应用是否存在,不存在注册
  19. mountMicroApp(unref(currentRoute).fullPath);
  20. resetMicroContentWH('micro-vent-3dModal', () => {
  21. loading.value = false;
  22. });
  23. });
  24. onBeforeUnmount(() => {
  25. unmountMicroApps(['/micro-vent-3dModal']);
  26. });
  27. return { loading };
  28. },
  29. });
  30. </script>
  31. <style lang="less" scoped>
  32. .loading-box {
  33. position: fixed;
  34. display: flex;
  35. align-items: center;
  36. justify-content: center;
  37. width: 100%;
  38. height: 100%;
  39. }
  40. #micro-vent-3dModal {
  41. position: absolute;
  42. left: 0;
  43. top: 0;
  44. width: 100%;
  45. height: 100%;
  46. pointer-events: auto;
  47. }
  48. </style>