React-发布为npm软件包的组件之间的通信和路由

时间:2020-01-31 14:02:41

标签: node.js reactjs redux rxjs react-router

我正在尝试为该项目设置微前端架构。该项目包含多个react应用。以下是项目结构:

  • 容器
  • 标题(npm包)
  • 仪表板(npm软件包)
  • app1(npm软件包)
  • app2(npm软件包)
  • app3(npm软件包)

在这里,容器充当其他应用程序的包装。仪表板应用程序显示指向其他应用程序的链接,例如app1,app2,app3等...

一旦用户登录标题,仪表板应用程序就会在页面上呈现。通过仪表板,用户可以导航到其他应用程序。

container

import React, { useState, useEffect } from 'react';
import Header from 'header';
import Dashboard from 'dashboard';
import { api } from '../api';

function storeUser(user) {
  if (user) {
    localStorage.user = JSON.stringify(user);
  } else {
    delete localStorage.user;
  }
}

function Container() {
  const [error, setError] = useState([]);
  const [user, setUser] = useState();

  const login = async () => {
    try {
      const user = await api({
        endpoint: 'identity/login',
        method: 'POST',
        json: {
          email: 'test@abc.com',
          password: '12345'
        }
      });
      setUser(user);
      storeUser(user);
    } catch (err) {
      setError(err.message);
    }
  };

  return (
    <div>
      <input type="submit" value="Login" onClick={() => login()}></input>
      {user ? (
        <div>
          <Header />
          <Dashboard />
        </div>
      ) : (
        <span>{error}</span>
      )}
    </div>
  );
}

export default Container;

dashboard

function Dashboard() {
  const [data, setData] = useState([]);

  useEffect(() => {
    const fetchData = async () => {
      const response = await getApps();
      setData(response);
    };
    fetchData();
  }, []);

  return (
    <ul>
      {data.map(item => (
        <li key={item.id}>{item.name}</li>
      ))}
    </ul>
  );
}

如何通知container li应用(发布为npm软件包)中的dashboard,并使用react-router渲染单击的组件/应用?

1 个答案:

答案 0 :(得分:0)

只需将带有回调的道具传递到仪表板根组件,并将其用作onClick处理程序:

容器:

<Dashboard onItemClicked={(itemUrl) => this.props.history.push(itemUrl)} />

仪表板:

<li key={item.id} onClick={() => this.props.onItemClicked(item.url)}>{item.name}</li>

然后,在调用此函数时,容器组件可以使用history API推送不同的路由。如果容器使用react-router(和withRouter),则它应该挂接到您设置的路由中。维护路径路径(字符串)的中央文件对此很有帮助。

或者,您可以将整个history道具传递到仪表板。