vue3异步组件加载

业务背景


业务上有个页面按流程节点展示不同模块,有可复用的,但顺序又不一致,不想用template if条件判断写多次,故提取各部分 作为子组件,按需加载


解决方式

template部分

<template>
  <h2>明细页</h2>
  <template v-for="component in components" :key="component">
    <component :is="component" />
  </template>
  <van-button @click="loadComp">load</van-button>
</template>

js部分

<script setup>
  import {
    defineAsyncComponent,
    shallowRef
  } from 'vue';
  
  // ✨ 以下是按需加载的组件,存在于./process文件夹下
  let dynamicArr = [
    'FaultConfirm',
    'DeviceInfo',
    'OrderInfo',
    'PartsInfo',
  ]
  let components = shallowRef([]); // 使用shallowRef ❗❗
  function loadComp() {
    let tempComponents = [];
    for (let i=0; i<dynamicArr.length; i++) { // for let循环,有序引入异步组件
      tempComponents.push(defineAsyncComponent(() => import(`./process/${dynamicArr[i]}.vue`))); // defineAsyncComponent ❗❗
    }
    components.value = tempComponents;
  }
</script>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值