如何解决React Component从props获取值并仅在第二次单击时状态
我第一次打开组件时出现错误,但道具没有显示值。当我单击以打开该组件时,道具的第二次值已正确到达,并且组件显示正确。道具到达时,我的组件中没有自动更新。与我的componentWillReceiveProps()
方法有什么关系,或者错误实际上可能在哪里?
这是我之间创建的非常嵌套的关系,但这是我用来更新状态并接收道具的组件:
class UserRegistrations extends React.Component {
state = {
registrations: []
}
componentDidMount() {
const userID = this.props.token
axios.get(`/api/userregistrationslist/${userID}`)
.then(res => {
this.setState({
registrations: res.data
})
console.log('Kasutaja regamised1',res.data)
});
}
render(){
return(<ListView reg={this.state.registrations} />)
}
}
class Event extends React.Component {
render() {
return(<div><TrainingCard id={this.props.id.event}/></div>)
}
}
class ListView extends React.Component {
state = {
regs: []
}
componentWillReceiveProps() {
const reg = this.props.reg
console.log('Propid1',this.props.reg)
this.setState({
regs: reg.map((registration) => <Event key={registration.id} id={registration} />)
},() => console.log('final regs',this.state.regs))
}
render(){
return(<ul>{this.state.regs}</ul>)
}
}
这是我插入了道具的TrainingCard组件:
class TrainingCard extends React.Component {
state = {
training: {}
}
componentDidMount() {
const trainingID = this.props.id
console.log('Item training props',this.props.id)
axios.get(`/api/${trainingID}/`)
.then(res => {
this.setState({
training: res.data
})
console.log('Componendi data',res.data)
})
}
render(){
return(<div className='trainingCard' ><Card title={this.state.training.title} style={{ width: 300 }}>
<p>Spordiala: {this.state.training.sport}</p>
<p>Asukoht: {this.state.training.location}</p>
<p><a href={`trainings/${this.state.training.id}`}>Link treeningule</a></p></Card></div>)
}
}
export default TrainingCard;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。