[英]React - Call props function inside of a components function
嘗試做這樣的事情:
//組件一
toggleDropdown() {
setState({open: !open}
}
render () {
return (
ChildComponent toggle={this.toggleDropdown} />
)
}
然后在我的子組件中,我想在另一個函數中調用該toggleDropdown函數,如下所示:
// This gets triggered on click.
removeItem() {
// remove scripts then:
this.props.toggleDropdown()
}
我以為您可以執行類似的操作,但是看來您只能在元素上調用prop函數?
傳遞給子組件的prop被命名為toggle
而不是toggleDropdown
,因此您需要像在removeItem組件中那樣調用它
// This gets triggered on click.
removeItem() {
this.props.toggle()
}
您可能需要做的其他事情是使用bind
或arrow functions
綁定removeItem
arrow functions
constructor(props) {
super(props);
this.removeItem = this.removeItem.bind(this);
}
要么
// This gets triggered on click.
removeItem = () => {
this.props.toggle()
}
您只需要調用toggle
而不是toggleDropdown
。
this.props.toggle();
子組件的toggleDropdown
命名為toggle
,而toggleDropdown
屬於父組件。
這應該在子組件中起作用:
removeItem() {
this.props.toggle();
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.