외부 (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
App 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();
react-router-redux
( github.com/reactjs/react-router-redux을 당신의 오래된 버전을 사용하여 적용 할 수있는 특별한 제약이없는 경우) react-redux
및 react-router
라이브러리를이 문제를 해결할 수 있습니다, 당신은, 새 버전으로 전환하는 것이 좋습니다 ). 어느 쪽이든 당신은 업그레이드를 수행하거나의 정확한 버전을 제공해야한다 react
, react-router-redux
, react-redux
그리고 react-router-dom
우리가 패치 솔루션을 찾을 수있는 기회를 가질 수 있도록 프로젝트가 현재 사용됩니다.
<Link>
컴포넌트를 인수 또는 소품으로 외부 라이브러리에 전달 하지 않습니까? 더 유연하고 네비게이션을 깔끔하게 처리 할 수 있습니다.