vue动态引入组件、批量引入组件方式(vue2,vue3)
更新时间:2026年02月10日 09:31:20 作者:无心使然云中漫步
文章总结了Vue 2和Vue 3中批量引入组件的方法,并详细说明了如何在模板中使用动态组件`component`根据key值渲染组件,文章还提供了一个示例函数来处理路径,并将组件动态引入到`componentList`中
vue2
批量全局引入:
import Vue from "vue"
const components = require.context(
'./', //组件所在目录的相对路径
false, //是否查询其子目录
/[A-Z]\w+\.(vue|js)$/ //匹配组件文件名的正则表达式
)
components.keys().forEach(fileName=>{
// 获取文件名
var names = fileName.split("/").pop().replace(/\.\w+$/,"");
// 获取组件配置
const comp = components(fileName);
// 若该组件是通过"export default"导出的,优先使用".default",
// 否则退回到使用模块的根
Vue.component(names,comp.default || comp);
})
批量局部引入:
<script>
// 引入所有需要的动态组件
const components = require.context(
"./", //组件所在目录的相对路径
true, //是否查询其子目录
/\w+.vue$/ //匹配基础组件文件名的正则表达式
);
const comObj = {};
components.keys().forEach(fileName => {
// 获取文件名
var names = fileName.split("/").pop().replace(/.\w+$/, "");
// 获取组件配置
const comp = components(fileName);
// 若该组件是通过"export default"导出的,优先使用".default",否则退回到使用模块的根
comObj[names] = comp.default || comp;
});
export default {
data() {
return {
}
},
mounted() {},
components: comObj
};
</script>
vue3
批量引入:
批量导入组件,在模板中利用动态组件component,根据key值渲染组件,注意这里的key类似‘./components/Component1.vue’这样的形式,如果需要去掉路径可以用函数处理再放入componentList
<template>
<component :is="componentList[componentName]"></component>
</template>
<script lang="ts" setup>
const componentList: Record<string, any> = reactive({});
const components = import.meta.glob('./components/**/*.vue');
Object.entries(components).forEach(async ([key, val]) => {
componentList[key] = defineAsyncComponent(val);
});
const props = defineProps({
componentName: {
type: String,
default: '',
},
});
</script>
动态引入:
<template>
<component :is="componentName"></component>
</template>
<script lang="ts" setup>
const props = defineProps({
componentName: {
type: String,
default: '',
},
});
const comp = defineAsyncComponent(() => import(`./components/${props.componentName}.vue`));
</script>
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vue中使用 ElementUi 的 el-select 实现全选功能(思路详解
在开发中,有一个需求是 选项组件中使用到一个 全选的功能,特在这记录下实现的方法,方便后续的查阅,以及方便大家查阅借鉴,对vue ElementUi 全选功能感兴趣的朋友一起看看吧2024-02-02


最新评论