vue进阶——动态引入组件

vue进阶——动态引入组件

根据 Vuex 存储中的 selectedMapComponent 动态计算组件路径,并在组件创建时和 selectedMapComponent 变化时加载对应的动态组件。

运行逻辑如下:

  1. 引入 Vue 3 的相关函数和 Vuex 中的 useStore 函数,以及组件需要使用的依赖库。

  2. 使用 useStore 函数获取 Vuex 的 store 对象。

  3. 利用 computed 函数创建一个计算属性 selectedMapComponent,它根据 Vuex 中的 selectedMapComponent 的值动态构建组件路径。这个计算属性使用 import() 函数返回一个 Promise,该 Promise 用于异步加载对应的组件,如果加载失败,则捕获错误并返回 null。

  4. 创建一个响应式变量 dynamicComponent 用于存储动态加载的组件。

  5. 定义 loadDynamicComponent 函数,该函数通过 await 等待 selectedMapComponent 的 Promise 解析,并将动态加载的组件赋值给 dynamicComponent。

  6. 使用 watch 函数监听 Vuex 中 selectedMapComponent 的变化,当发生变化时,调用 loadDynamicComponent 函数重新加载动态组件。设置 { immediate: true } 选项,确保在组件初始化时也会立即调用一次。

  7. 在组件创建时,调用 onMounted 钩子,执行 loadDynamicComponent 函数,以确保初始时动态组件的加载。

<template>
	<component :is="dynamicComponent" />
</template>

<script setup>
import { ref, onMounted, computed, watch } from 'vue';
import { useStore } from 'vuex';

const store = useStore();

// 计算属性,根据 store 中的 selectedMapComponent 动态计算组件路径
const selectedMapComponent = computed(() => {
    // 获取 selectedMapComponent 的值
    const mapType = store.state.selectedMapComponent;

    // 构建组件路径
    const componentPath = `./city/${mapType}.vue`;

    // 使用 import() 返回一个 Promise,加载组件
    return import(componentPath)
        .catch((error) => {
            // 处理加载错误,打印错误信息并返回 null
            console.error('Error loading component:', error);
            return null;
        });
});

// 动态组件的引用
const dynamicComponent = ref(null);

const loadDynamicComponent = async () => {
    try {
        const module = await selectedMapComponent.value;
        dynamicComponent.value = module.default;
    } catch (error) {
        console.error('Error loading component:', error);
    }
};

// 使用 watch 监听 selectedMapComponent 的变化
watch(() => store.state.selectedMapComponent, loadDynamicComponent, { immediate: true });

onMounted(() => {
    loadDynamicComponent();
});
</script>

相关推荐

  1. vue——动态引入组件

    2024-03-14 09:32:09       20 阅读
  2. Vue实现动态引入组件

    2024-03-14 09:32:09       29 阅读
  3. Vue2——组件通信

    2024-03-14 09:32:09       17 阅读
  4. vue3

    2024-03-14 09:32:09       18 阅读
  5. vue

    2024-03-14 09:32:09       7 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-14 09:32:09       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-14 09:32:09       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-14 09:32:09       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-14 09:32:09       18 阅读

热门阅读

  1. 大带宽服务器的作用有哪些?

    2024-03-14 09:32:09       18 阅读
  2. 本地socket通信服务器,客户端

    2024-03-14 09:32:09       20 阅读
  3. 【无标题】

    2024-03-14 09:32:09       18 阅读
  4. C#中IEnumerable<string>和IList<string>的区别

    2024-03-14 09:32:09       19 阅读
  5. C# 中多线程锁的使用经验

    2024-03-14 09:32:09       18 阅读
  6. ffmpeg的使用不简单

    2024-03-14 09:32:09       23 阅读
  7. 小结:Node.js Express VS Koa

    2024-03-14 09:32:09       21 阅读
  8. AcWing 503. 借教室(每日一题)

    2024-03-14 09:32:09       18 阅读
  9. shell脚本中数组元素赋值

    2024-03-14 09:32:09       18 阅读
  10. 「jQuery系列」jQuery Cookie插件功能介绍

    2024-03-14 09:32:09       21 阅读
  11. 在 Amazon Bedrock 上使用 Anthropic Claude 系统 Prompt

    2024-03-14 09:32:09       18 阅读