আমি আমার বাহ্যিক (নোড_মডিউলস) প্যাটার্ন লাইব্রেরি থেকে উপাদানগুলি রেন্ডার করছি। আমার প্রধান অ্যাপ্লিকেশনটিতে, আমি আমার 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();
react-router-redux
( github.com/reactjs/react-router-redux ,) যদি না আপনি এর সেকেলে সংস্করণগুলি ব্যবহার জোরদার করা একটি বিশেষ বাধ্যতা আছে react-redux
এবং react-router
লাইব্রেরি, আপনি, নতুন সংস্করণে থেকে সরানোর বিবেচনা করা উচিত যেমন আপনার সমস্যাটির সমাধান হতে পারে )। হয় আপনি আপগ্রেড, বা আপনি সঠিক সংস্করণ প্রদান করা উচিত react
, react-router-redux
, react-redux
এবং react-router-dom
তাই আমরা একটি প্যাচিং সমাধান খুঁজে বের করার একটি সুযোগ আছে আপনার প্রকল্পের বর্তমানে ব্যবহার করা হয়।
<Link>
উপাদানটি আর্গুমেন্ট বা প্রপস হিসাবে আপনার বাহ্যিক কাজকে কেন দেওয়া হচ্ছে না ? এটি আরও নমনীয়তা এবং নেভিগেশন পরিচালনা করার তার পরিষ্কার উপায়টিকে মঞ্জুরি দেয়।