react 使用@loadable/component 实现路由动态懒加载

踩坑记录
  • 动态引入import()变量失效问题, import不能导入变量字符串的路径问题
  • 因为webpack的现在的实现方式不能实现完全动态,所以可以通过字符串模板来提供部分信息给webpack,如下
    在这里插入图片描述
/**
 * 根据已经获取的菜单组合需要生成的路由
 * @param list 数据
 * @param parentPath 父级的路径,组合子级可访问路径
 */
const combinationRouting = (list: Menus[], parentPath?: string) => {

  let portMenu: PortfolioMenuType[] = [];
  list.forEach((item: Menus) => {
    const path = parentPath ? parentPath + item.url : item.url;

    const obj: PortfolioMenuType = {
      path,
      component: () => import(`../pages${path}/index`),
      name: item.id,
    };
    // 是否存在子级
    if (item.children && item.children.length > 0) {
      const result: PortfolioMenuType[] = combinationRouting(item.children, item.url);
      portMenu = portMenu.concat(result);
    }
    if (!parentPath) {
      portMenu.push(obj);
    }
  });
  return portMenu;
}

export { combinationRouting }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值