【发布时间】:2020-04-25 01:28:32
【问题描述】:
我正在从我的外部 (node_modules) 模式库中渲染组件。在我的主应用程序中,我将 Link 实例从 react-router-dom 传递到我的外部库的组件中,如下所示:
import { Link } from 'react-router-dom';
import { Heading } from 'my-external-library';
const articleWithLinkProps = {
url: `/article/${article.slug}`,
routerLink: Link,
};
<Heading withLinkProps={articleWithLinkProps} />
在我的库中,它正在渲染Link:
const RouterLink = withLinkProps.routerLink;
<RouterLink
to={withLinkProps.url}
>
{props.children}
</RouterLink>
RouterLink 似乎正确呈现,甚至在单击时导航到 URL。
我的问题是 RouterLink 似乎已与我的应用程序的 react-router-dom 实例分离。当我点击Heading 时,它会“硬”导航,回发页面,而不是像Link 通常那样无缝地路由到那里。
目前我不确定要尝试什么来让它无缝导航。任何帮助或建议将不胜感激,在此先感谢您。
编辑:显示我的路由器是如何设置的。
import React from 'react';
import { hydrate, unmountComponentAtNode } from 'react-dom';
import { AppContainer } from 'react-hot-loader';
import { Provider } from 'react-redux';
import { createBrowserHistory } from 'history';
import { ConnectedRouter } from 'react-router-redux';
import RedBox from 'redbox-react';
import { Route } from 'react-router-dom';
import { Frontload } from 'react-frontload';
import App from './containers/App';
import configureStore from './redux/store';
import withTracker from './withTracker';
// Get initial state from server-side rendering
const initialState = window.__INITIAL_STATE__;
const history = createBrowserHistory();
const store = configureStore(history, initialState);
const mountNode = document.getElementById('react-view');
const noServerRender = window.__noServerRender__;
if (process.env.NODE_ENV !== 'production') {
console.log(`[react-frontload] server rendering configured ${noServerRender ? 'off' : 'on'}`);
}
const renderApp = () =>
hydrate(
<AppContainer errorReporter={({ error }) => <RedBox error={error} />}>
<Provider store={store}>
<Frontload noServerRender={window.__noServerRender__}>
<ConnectedRouter onUpdate={() => window.scrollTo(0, 0)} history={history}>
<Route
component={withTracker(() => (
<App noServerRender={noServerRender} />
))}
/>
</ConnectedRouter>
</Frontload>
</Provider>
</AppContainer>,
mountNode,
);
// Enable hot reload by react-hot-loader
if (module.hot) {
const reRenderApp = () => {
try {
renderApp();
} catch (error) {
hydrate(<RedBox error={error} />, mountNode);
}
};
module.hot.accept('./containers/App', () => {
setImmediate(() => {
// Preventing the hot reloading error from react-router
unmountComponentAtNode(mountNode);
reRenderApp();
});
});
}
renderApp();
【问题讨论】:
-
为什么不将您的
<Link>组件作为参数或道具传递给您的外部库?这将允许更大的灵活性及其处理导航的简洁方式。 -
您能展示一下您是如何设置路由器的吗?它是浏览器、内存还是静态路由器?
-
@mamounothman - 这就是目前的做法,但似乎会影响它导航到回发的方式。
-
您正在使用已弃用的库
react-router-redux(github.com/reactjs/react-router-redux),除非您有特殊限制来强制使用过时版本的react-redux和react-router库,否则您应该考虑迁移到较新的版本,因为它可能会解决您的问题)。要么进行升级,要么提供您的项目当前使用的react、react-router-redux、react-redux和react-router-dom的确切版本,以便我们有机会找到修补解决方案。 -
如果链接直接与同一个 URL 一起使用(而不是先将其代理到库),您能否确认一切正常?
标签: javascript reactjs react-router-dom