簡體   English   中英

React-在組件函數內部調用props函數

[英]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()
}

您可能需要做的其他事情是使用bindarrow 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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM