2 reactjs react-router react-router-v4 react-router-dom
在过去的几天里,我一直试图让我的嵌套路由正常工作,我不得不说我完全迷失了。
我正在尝试使以下功能正常工作:
{ BankingCards }在{ CardWrapper }.<Link>由 呈现的 4 张卡片之一时{ BankingCards },我想将嵌套路径呈现在同一个{ CardWrapper }.在下面的代码块中,您会注意到我尝试使用 switch 语句将组件动态分配给actionComponent. 这似乎以不止一种方式破坏了功能。
这是错误的方法,还是我错过了有关 React Router 组件的某些内容?
// Banking.js
import CardWrapper from '../../Wrappers/CardWrapper/CardWrapper';
import BankingCards from './BankingCards/BankingCards';
import AddBank from './AddBank/AddBank';
import AddDebit from './AddDebit/AddDebit';
import AddCredit from './AddCredit/AddCredit';
import AddDirect from './AddDirect/AddDirect';
class Banking extends Component {
state = {};
render() {
const { match } = this.props;
console.log(match.params);
// let actionComponent;
// switch (match.params.actionType) {
// case 'add-bank':
// actionComponent = AddBank;
// break;
// case 'add-debit':
// actionComponent = AddDebit;
// break;
// case 'add-credit':
// actionComponent = AddCredit;
// break;
// case 'add-direct':
// actionComponent = AddDirect;
// break;
// default:
// return null;
// }
return (
<div className={classes.Banking}>
<h1 className={classes.mainHeader}>Banking</h1>
<CardWrapper>
<Switch>
<Route exact path={`${match.path}`} component={BankingCards} />
<Route path={`${match.path}/:actionType`} component={actionComponent} />
</Switch>
</CardWrapper>
</div>
)
}
}
Run Code Online (Sandbox Code Playgroud)
和
// BankingCards.js
const bankingCards = ({ match }) => {
return (
<>
<Card>
<h1>Add Bank Account</h1>
<Link to={`${match.url}/add-bank`}>
<SVG src={iconPlus} className={classes.iconPlus} />
</Link>
<h3>Manage accounts</h3>
</Card>
<Card>
<h1>Add Debit Card</h1>
<Link to={`${match.url}/add-debit`}>
<SVG src={iconPlus} className={classes.iconPlus} />
</Link>
<h3>Manage debit cards</h3>
</Card>
<Card>
<h1>Add Credit Card</h1>
<Link to={`${match.url}/add-credit`}>
<SVG src={iconPlus} className={classes.iconPlus} />
</Link>
<h3>Manage credit cards</h3>
</Card>
<Card>
<h1>Add Direct Debit</h1>
<Link to={`${match.url}/add-direct`}>
<SVG src={iconPlus} className={classes.iconPlus} />
</Link>
<h3>Manage direct debits</h3>
</Card>
</>
);
};
Run Code Online (Sandbox Code Playgroud)
小智 5
更新:在网站上深入挖掘后找到了解决方案
我的代码有 3 个问题:
我应该使用renderprop 而不是componentdynamic Route。
<Switch>
<Route path={`${match.path}/:actionType`} render={props => {
const actionType = props.match.params.actionType;
const Component = getActionComponent(actionType);
if (Component) {
return <Component {...props} />;
} else {
return <Redirect to="/" />
}
}} />
<Route path={`${match.path}`} component={BankingCards} />
</Switch>
Run Code Online (Sandbox Code Playgroud)此外,动态路由应该在/banking第一条之前出现。这是因为该Switch语句只会呈现第一个匹配项。/banking已经是部分匹配,所以路由器没有到达像/banking/add-bank.
父路由/banking将exactprop 设置为true。我现在知道当使用嵌套路由时,父路由不应该exact启用。
class MainArea extends Component {
state = {};
render() {
return (
<div className={classes.MainArea}>
<Route path="/banking" component={Banking} />
<Route exact path="/planner" component={Planner} />
<Route exact path="/notes" component={Notes} />
</div>
);
}
}
Run Code Online (Sandbox Code Playgroud)| 归档时间: |
|
| 查看次数: |
2461 次 |
| 最近记录: |