vue进阶——动态引入组件

本文介绍了如何在Vue3应用中,通过Vuex管理状态,实现根据selectedMapComponent动态导入并显示对应的城市组件。使用了import()函数进行异步加载,并利用watch和computed确保组件在状态变化时及时更新。
摘要由CSDN通过智能技术生成

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>

Vite动态引入

使用 import() 函数异步加载对应的组件文件。加载完成后,返回加载的组件对象

const selectedMapComponent = computed(async () => {
    const mapType = store.state.selectedMapComponent;

    const componentPath = await import(`./city/${mapType}.vue`);

    return componentPath;
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋书一叶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值