ventModal.vue 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. <template>
  2. <div style="position: absolute; width: 100%; height: 100%" class="modal-bg">
  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 } from 'vue';
  9. import { unmountMicroApps, mountMicroApp } from '/@/qiankun';
  10. import { resetMicroContentWH } from '/@/utils/domUtils';
  11. export default defineComponent({
  12. name: 'VentModel',
  13. setup() {
  14. const loading = ref(true);
  15. onMounted(() => {
  16. // 判断子应用是否存在,不存在注册
  17. mountMicroApp('micro-vent-3dModal', true);
  18. resetMicroContentWH('micro-vent-3dModal', () => {
  19. loading.value = false;
  20. });
  21. });
  22. onBeforeUnmount(async () => {
  23. await unmountMicroApps(['micro-vent-3dModal']);
  24. });
  25. return { loading };
  26. },
  27. });
  28. </script>
  29. <style lang="less" scoped>
  30. .modal-bg {
  31. background: url('/@/assets/images/beltFire/baseMap.png') no-repeat center;
  32. }
  33. .loading-box {
  34. position: fixed;
  35. display: flex;
  36. align-items: center;
  37. justify-content: center;
  38. width: 100%;
  39. height: 100%;
  40. }
  41. #micro-vent-3dModal {
  42. position: absolute;
  43. left: 0;
  44. top: 0;
  45. width: 100%;
  46. height: 100%;
  47. pointer-events: auto;
  48. }
  49. </style>