ส่งลิงก์ของ react-router-dom ลงในไลบรารีภายนอก


10

ฉันกำลังสร้างการแสดงผลคอมโพเนนต์จากไลบรารีรูปแบบภายนอก (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>องค์ประกอบของคุณส่งต่อไปยัง lib ภายนอกของคุณเป็นอาร์กิวเมนต์หรืออุปกรณ์ประกอบฉาก? ที่จะช่วยให้มีความยืดหยุ่นมากขึ้นและวิธีการจัดการการนำทางที่สะอาด
Ma'moun othman

คุณสามารถแสดงวิธีตั้งค่าเราเตอร์ของคุณได้อย่างไร มันเป็นเบราว์เซอร์หน่วยความจำหรือเราเตอร์แบบคงที่?
zero298

@ zero298 - อัปเดตคำถาม
danjones_mcr

@mounounothman - นั่นเป็นวิธีการที่กำลังทำอยู่ แต่ดูเหมือนว่าจะส่งผลกระทบต่อวิธีการนำทางไปยังการโพสต์กลับ
danjones_mcr

คุณกำลังใช้ห้องสมุดเลิกreact-router-redux( github.com/reactjs/react-router-redux ) เว้นแต่คุณจะมีข้อ จำกัด พิเศษในการบังคับใช้รุ่นเก่าของreact-reduxและreact-routerห้องสมุดที่คุณควรพิจารณาการย้ายไปยังรุ่นใหม่มันก็อาจจะแก้ไขปัญหาของคุณ ) ไม่ว่าคุณจะทำอัพเกรดหรือคุณควรให้รุ่นที่แน่นอนของreact, react-router-redux, react-reduxและreact-router-domโครงการของคุณในปัจจุบันคือการใช้เพื่อให้เรามีโอกาสที่จะหาวิธีการแก้ปัญหาที่ปะ
GonArrivi

คำตอบ:


2

ฉันสร้างกรณีการใช้งานของคุณใหม่codesandbox.ioและ "การเปลี่ยนแปลง" ทำงานได้ดี ดังนั้นการตรวจสอบการใช้งานของฉันอาจช่วยคุณได้ อย่างไรก็ตามฉันแทนที่การนำเข้าไฟล์ด้วยการนำเข้าไฟล์ดังนั้นฉันไม่ทราบว่าเป็นปัจจัยชี้ขาดว่าทำไมมันจึงไม่ทำงานหากไม่มีการโหลดซ้ำทั้งหน้า

โดยวิธีการที่คุณหมายถึงอะไรโดย "ต่อเนื่อง"? มีองค์ประกอบที่อยู่ในทุกหน้าและไม่ควรโหลดซ้ำอีกครั้งเมื่อคลิกที่ลิงค์หรือไม่ นี่เป็นเหมือนที่ฉันนำไปใช้ในกล่องทรายที่มีภาพนิ่งอยู่ด้านบนของทุกหน้า


ตรวจสอบSandbox

นี่คือexample.jsไฟล์

// This sandbox is realted to this post https://stackoverflow.com/q/59630138/965548

import React from "react";
import { BrowserRouter as Router, Route, Link } from "react-router-dom";
import { Heading } from "./my-external-library.js";

export default function App() {
  return (
    <div>
      <img
        alt="flower from shutterstock"
        src="https://image.shutterstock.com/image-photo/pink-flowers-blossom-on-blue-600w-1439541782.jpg"
      />
      <Router>
        <Route exact={true} path="/" render={Welcome} />
        <Route path="/article/coolArticle" component={CoolArticleComponent} />
      </Router>
    </div>
  );
}

const Welcome = () => {
  const articleWithLinkProps = {
    url: `/article/coolArticle`,
    routerLink: Link
  };

  return (
    <div>
      <h1>This is a super fancy homepage ;)</h1>
      <Heading withLinkProps={articleWithLinkProps} />
    </div>
  );
};

const CoolArticleComponent = () => (
  <div>
    <p>This is a handcrafted article component.</p>
    <Link to="/">Back</Link>
  </div>
);

และนี่คือmy-external-library.jsไฟล์:

import React from "react";

export const Heading = ({ withLinkProps }) => {
  const RouterLink = withLinkProps.routerLink;
  return <RouterLink to={withLinkProps.url}>Superlink</RouterLink>;
};

สวัสดีขอบคุณมากสำหรับคำตอบ! ดูเหมือนว่าเฉพาะเมื่อผ่าน node_modules ปัญหาจะเกิดขึ้น
danjones_mcr
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.