Я рендеринг компонентов из моей внешней (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();
javascript
reactjs
react-router-dom
danjones_mcr
источник
источник
<Link>
передать ваш компонент во внешнюю библиотеку в качестве аргумента или поддержки? это позволило бы больше гибкости и его чистый способ обработки навигации.react-router-redux
( github.com/reactjs/react-router-redux ), если вы не имеете специальное ограничение для обеспечения соблюдения с использованием устаревших версийreact-redux
иreact-router
библиотек, вы должны рассмотреть вопрос о переходе на новые версии, так как это может решить вашу проблему ). Либо вы делаете обновление, или вы должны предоставить точные вариантыreact
,react-router-redux
,react-redux
иreact-router-dom
ваш проект в настоящее время использует поэтому у нас есть шанс найти решение внесения исправлений.Ответы:
Я восстановил ваш вариант использования в
codesandbox.io
и «переход» работает нормально. Так что, возможно, проверка моей реализации может вам помочь. Однако я заменил импорт библиотеки импортом файла, поэтому не знаю, является ли это решающим фактором того, почему он не работает без перезагрузки всей страницы.Кстати, что вы имеете в виду именно под "бесшовно"? Существуют ли элементы, которые остаются на каждой странице и не должны повторно загружаться при нажатии на ссылку? Это похоже на то, как я реализовал это в песочнице, где статическая картинка остается наверху на каждой странице.
Проверьте песочницу .
Это
example.js
файлИ это
my-external-library.js
файл:источник