加载远程.vue文件并使用(Vue3版)

之前写了基于Vue2版的加载远程.vue组件,后面有友友问关于 Vue3 的版本,经过踩坑实践后写出来了记录一下。

vue3-sfc-loader 插件

Vue3/Vue2单文件组件加载器 在运行时从html/js/string动态加载.vue文件并转成响应式组件

loadModule 导入

Vue3 的导入路径和Vue2有点不一样,我这里使用esm版本

js 复制代码
// Vue3 esm 版
import { loadModule } from 'vue3-sfc-loader/dist/vue3-sfc-loader.esm.js'

获取Vue

因为Vue3 不默认导出Vue了,所以这里直接导入所有

js 复制代码
import * as Vue from 'vue'

远程加载

loadModule 第一个参数是组件路径字符串,会传入getFile方法中

getFilehttp 获取远程组件文件,此处我使用fetch API ,请求成功后调text() 返回 最终就是返回的一个字符串文本

这里使用Vue3 defineAsyncComponent 加载组件

js 复制代码
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 动态渲染

同时传递属性和绑定事件

js 复制代码
<component :is="asyncComponent" v-bind="$attrs"/>

完整代码

js 复制代码
<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>
相关推荐
Kagol28 分钟前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉30 分钟前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau31 分钟前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生33 分钟前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼41 分钟前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范
明君8799744 分钟前
Flutter 如何给图片添加多行文字水印
前端·flutter
进击的尘埃1 小时前
AI 代码审查工具链搭建:用 AST 解析 + LLM 实现自动化 Code Review 的前端工程方案
javascript
juejin_cn1 小时前
[转][译] 从零开始构建 OpenClaw — 第五部分(对话压缩)
javascript
leolee181 小时前
Redux Toolkit 实战使用指南
前端·react.js·redux
bluceli1 小时前
React Hooks最佳实践:写出优雅高效的组件代码
前端·react.js