繁体   English   中英

Javascript:使用闭包概括react-loadable

[英]Javascript: generalizing react-loadable with closure

我正在使用react-loadable加载视图。 下面的代码工作正常:

const Home = Loadable({
    loader: () =>
        import ('./views/home'),
    loading: Loading,
});

但是我有多个视图,因此我想通过用变量替换路径字符串来概括(重构)以上代码。 这就是问题开始的地方。 我尝试了以下技术,但它不会加载目标视图,而是仅保留“ 加载”视图,这只是一个临时视图,仅包含“ Loading ...”字符串。

const getLoadableView = (viewPath) => {
  return Loadable({
    loader: ((p) => {
      const m = p;
      return () => {
        console.log(m); //this one prints the correct value
        return import(m);
      };
    })(viewPath),
    loading: Loading
  });
}
const Home = getLoadableView('./views/home');

我想念什么吗? 谢谢。

我通过以下技巧解决了此问题:

const getLoadableView = (viewPath) => {
  return Loadable({
    loader: () => import(`./${viewPath}`);;
    })(viewPath),
    loading: Loading
  });
}
const homeViewPath = 'views/home';
const Home = getLoadableView(homeViewPath);

您可能会注意到,我没有做任何特别的事情,只是将路径分为两部分。 第一条路径在导入调用中进行了硬编码。

显然,这不是一个可靠的解决方案,但是我找不到这种导入调用行为的真正原因。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM