【发布时间】:2020-09-10 22:46:08
【问题描述】:
我有两个组件,一个是 AddList 组件,第二个是 DetailList 组件。我正在做的是每个 li 中都有一个 AddList 组件和按钮的列表。每当用户单击任何按钮时,该特定 LI 的相应 ID 和名称都会发送到 DetailList 组件,以便用户可以阅读有关该特定产品的更多信息。
我正在使用反应路由器,当我在路由中传递一个参数时,一切正常。我可以控制台记录受人尊敬的 ID <Route exact path="/details/:id" component={DetailOffAdd} />。但是当我在路由<Route exact path="/details/:id/:name" component={DetailOffAdd} /> 中传递第二个参数时,我的组件没有安装,也没有显示任何错误。它也不会控制我在 DetailList 组件中打印的 id 和 name。
这是我的AddList
导出默认类 Addlist 扩展组件 { 构造函数(道具){ 超级(道具) 这个.state = { 帖子:[] } }
passToDetailList(id,name) {
this.props.history.push('/details/'+id+name)
}
render() {
const { posts } = this.state;
return (
<div className="container" id="listOfAdd">
<ul className="addUl">
{
posts.map(post => {
return (
<li key={post.id}>
<button onClick={() => this.passToDetailList(post.id, post.add_title)}>VIEW</button>
</li>
);
})}
</ul>
</div>
**And the DetailList Component**
export default class DetailOffAdd extends Component {
componentDidMount(){
console.log(this.props.match.params.id)
}
render() {
return (
<Fragment>
Some code
</Fragment>
)
}
}
【问题讨论】:
标签: javascript reactjs jsx