Code-coder 2023-08-22 16:02 采纳率: 44.7%
浏览 12
已结题

vue3 怎么使用动态import按需加载组件?

component: (resolve) => require([@/views${data.path}.vue], resolve)

在vue cli4.x , Router4创建的项目。

在做按需加载组件时,component: (resolve) => require([@/views${data.path}.vue], resolve),组件需要根据后台传入的地址进行加载,也就是动态import语法,这样webpack编译时能够找到相应的组件。但是上面这种写法在编译时,发现控制台报错No match found for location with path,总是匹配不到路径。

  • 写回答

1条回答 默认 最新

  • 伟庭师兄weiting 2023-08-22 22:31
    关注
    
    <script lang="ts" setup>
    import { defineAsyncComponent, ref } from 'vue'
    
    // 需要加载的组件集合
    const components = ref(new Map<string, any>())
    components.value.set(
      'MyTag',
      defineAsyncComponent(() => import('./MyTag.vue'))
    )
    components.value.set(
      'Item',
      defineAsyncComponent(() => import('./Item.vue'))
    )
    // 默认加载的组件名
    const compName = ref('MyTag')
    // 组件切换
    function onClick() {
      if (compName.value === 'MyTag') {
        compName.value = 'Item'
      } else {
        compName.value = 'MyTag'
      }
    }
    </script>
    
    <template>
      <div>
        <el-button @click="onClick">改变组件</el-button>
        <component :is="components.get(compName)"></component>
      </div>
    </template>
    
    <style lang="scss" scoped></style>
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月30日
  • 已采纳回答 8月22日
  • 创建了问题 8月22日

悬赏问题

  • ¥20 Html备忘录页面制作
  • ¥15 黄永刚的晶体塑性子程序中输入的材料参数里的晶体取向参数是什么形式的?
  • ¥20 数学建模来解决我这个问题
  • ¥15 计算机网络ip分片偏移量计算头部是-20还是-40呀
  • ¥15 stc15f2k60s2单片机关于流水灯,时钟,定时器,矩阵键盘等方面的综合问题
  • ¥15 YOLOv8已有一个初步的检测模型,想利用这个模型对新的图片进行自动标注,生成labellmg可以识别的数据,再手动修改。如何操作?
  • ¥30 NIRfast软件使用指导
  • ¥20 matlab仿真问题,求功率谱密度
  • ¥15 求micropython modbus-RTU 从机的代码或库?
  • ¥15 django5安装失败