在react中调用作为props传递的方法

IT技术 javascript reactjs react-native methods react-router
2021-05-26 17:17:06

我的父元素中有方法,di 将它作为props传递;像这样:

<NavBar retrieveList={this.retrieveList}/>

在我的子组件中,我无法从另一个方法体调用此方法。

handleCloseModal () {
    window.$('#newHireModal').modal('hide');   /* this is working */
    console.log(this.props.retrieveList);     /* it gives method body, just to be sure props is coming here */
    this.props.retrieveList;   /*it gives "Expected an assignment or function call..." */
    this.props.retrieveList();   /*it gives "this.props.retrieveList is not a function" */
    return this.props.retrieveList;   /*it does nothing. no working, no error. */
  }

顺便说一下,我有构造函数和绑定;

constructor(props) {
    super(props);
    this.handleCloseModal = this.handleCloseModal.bind(this);
retrieveList() {
    StaffDataService.getAll()
      .then(response => {
        this.setState({
          staffWithBasics: response.data,
          filteredItems: response.data,
        });
      })
      .catch(e => {
        console.log(e);
      });
  }

这段代码有什么问题,我该如何运行这个父方法?

1个回答

发生这种情况是因为this接收委托的组件this中的 与函数中使用的不同传递时必须绑定它。

<NavBar retrieveList={this.retrieveList.bind(this)}/>

然后你可以在你的函数体中调用它,如下所示。

this.props.retrieveList();