Heim > Web-Frontend > View.js > Hauptteil

vue3动态加载组件及动态引入组件怎么使用

王林
Freigeben: 2023-05-11 12:01:14
nach vorne
3295 人浏览过

1.问题

在做一个用vite构建的vue3项目时,动态拉取导入.vue页面,然后控制台一直有以下提示,页面也无法渲染出来。

vue3动态加载组件及动态引入组件怎么使用

2.分析

根据上面的报错提示,让我们安装并使用:@rollup/plugin-dynamic-import-vars 这个插件(最终没有这个方案)。

Vite官方文档说需要使用Glob 导入形式,然后看了一个Glob的文档,解决了这个问题(亲测可行)。

首先需要使用特殊的import.meta.glob函数从文件系统导入多个模块:

const modules = import.meta.glob('../views/*/*.vue');
Nach dem Login kopieren

他会匹配并导入所有相关的组件:

// vite 生成的代码
const modules = {
  './views/foo.vue': () => import('./views/foo.vue'),
  './views/bar.vue': () => import('./views/bar.vue')
}
Nach dem Login kopieren

那么回到项目中,在home文件夹下的index.vue文件中导入custom_components文件夹下的所有.vue文件

vue3动态加载组件及动态引入组件怎么使用

因此,根据vite的import.meta.glob函数:就可以获得对应的custom_components文件夹下的.vue文件

const changeComponents = (e:string)=>{
	const link = modules[`../custom_components/${e}.vue`]
	console.log(link,'link')
}
Nach dem Login kopieren

打印link可以看到

vue3动态加载组件及动态引入组件怎么使用

最后就是异步注册组件

layouts.value = markRaw(defineAsyncComponent(link))
Nach dem Login kopieren

3.最后

下面贴出完整案例,仅供参考。有更好的或者需要优化的可以提问一起探讨。



Nach dem Login kopieren

以上是vue3动态加载组件及动态引入组件怎么使用的详细内容。更多信息请关注PHP中文网其他相关文章!

Verwandte Etiketten:
Quelle:yisu.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!