我正在尝试为该项目设置微前端架构。该项目包含多个react
应用。以下是项目结构:
在这里,容器充当其他应用程序的包装。仪表板应用程序显示指向其他应用程序的链接,例如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
渲染单击的组件/应用?
答案 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
道具传递到仪表板。