所以情况就是这样 - 当点击 a 时Link
,nprogress 栏将启动,我希望 react-router 仅在异步加载完成后用匹配的路由替换当前组件..就像在 instagram 中一样..
但我只得到这个 -
这是我异步加载组件的 HOC——
import React, { useEffect, useState } from "react";
import nprogress from "nprogress";
import "nprogress/nprogress.css";
export default importComponent => props => {
const [loadedComponent, setComponent] = useState(null);
// this works like componentwillMount
if (!nprogress.isStarted()) nprogress.start();
if (loadedComponent) nprogress.done();
useEffect(() => {
let mounted = true;
mounted &&
importComponent().then(
({ default: C }) => mounted && setComponent(<C {...props} />)
);
// componentUnMount
return () => (mounted = false);
}, []);
// return the loaded component
const Component = loadedComponent || <div style={{ flexGrow: 1 }}>..</div>;
return Component;
};
我在互联网上的任何地方都没有找到解决方案。所以我在stackoverflow中问了这个问题。我希望这里有人可以解决这个问题。