加载远程.vue文件并使用(Vue3版)
vue3-sfc-loader 插件
Vue3/Vue2单文件组件加载器 在运行时从html/js/string动态加载.vue文件并转成响应式组件
loadModule 导入
Vue3的导入路径和Vue2有点不一样,我这里使用esm版本
// Vue3 esm 版
import { loadModule } from 'vue3-sfc-loader/dist/vue3-sfc-loader.esm.js'
获取Vue
因为Vue3不默认导出Vue了,所以这里直接导入所有
import * as Vue from 'vue'
远程加载
loadModule 第一个参数是组件路径字符串,会传入getFile方法中
在getFile走http获取远程组件文件,此处我使用fetch API,请求成功后调text() 返回 最终就是返回的一个字符串文本
这里使用Vue3 defineAsyncComponent 加载组件
const options = {
moduleCache: {
vue: Vue,
},
async getFile (url: string) {
return await fetch(url).then(res => res.text())
},
addStyle () {
/* unused here */
},
}
const asyncComponent = defineAsyncComponent(() => loadModule('/vue/v3test.vue', options))
渲染组件
渲染就使用 :is 动态渲染
同时传递属性和绑定事件
<component :is="asyncComponent" v-bind="$attrs"/>
完整代码
<template>
<div>
<component :is="asyncComponent" v-bind="$attrs"/>
</div>
</template>
<script setup lang="ts">
import * as Vue from 'vue'
import { loadModule } from 'vue3-sfc-loader/dist/vue3-sfc-loader.esm.js'
import { defineAsyncComponent } from 'vue'
const options = {
moduleCache: {
vue: Vue,
},
async getFile (url: string) {
return await fetch(url).then(res => res.text())
},
addStyle () {
/* unused here */
},
}
const asyncComponent = defineAsyncComponent(() => loadModule('/vue/v3test.vue', options))
</script>
转载自:https://juejin.cn/post/7277828214247915539