在react中从父级调用子组件方法

IT技术 reactjs
2021-04-18 10:11:33

我有一个名为List 的简单组件,它是一个简单的ul里面有一些li每个li都是一个简单的组件。我还有其他父组件,它们呈现一个输入字段和List组件。点击发送键,我会捕捉输入字段的文本。例如,我想调用一个名为handleNewText(inputText) 的函数,但该函数需要保留在 List 组件中,因为我用来填充其他li组件的状态存在于List组件中。

我不想重构ListMyParent组件将数据管理从 传递ListMyParent

第一个是父母,第二个是孩子

class TodoComp extends React.Component {
  constructor(props){
    super(props);
    this.handleKeyPress = this.handleKeyPress.bind(this);
  }

  componentDidMpunt(){
    console.log(this._child.someMethod());
  }


  handleKeyPress(event){
    if(event.key === 'Enter'){
      var t = event.target.value;

    }
  }

  render(){
    return (
        <div>
          <input
            className="inputTodo"
            type="text"
            placeholder="want to be an hero...!"
            onKeyPress={this.handleKeyPress}
          />
          <List/>
        </div>
    );
  }

}


export default class List extends React.Component {
  constructor() {
    super();
    this.flipDone = this.flipDone.bind(this);
    this.state = {
      todos: Array(3).fill({ content: '', done: false})
    };
  }

  flipDone(id) {
    let index = Number(id);

    this.setState({
      todos: [
        ...this.state.todos.slice(0, index),
        Object.assign({}, this.state.todos[index], {done: !this.state.todos[index].done}),
        ...this.state.todos.slice(index + 1)
      ]
    });
  }

  render() {

    const myList = this.state.todos.map((todo, index) => {
      return (
        <Todo key={index}
              clickHandler={this.flipDone}
              id={index}
              todo={todo}
              handleText={this.handleText}
        />
      );
    })

    return (
      <ul className="list">
        {myList}
      </ul>
    );
  }


ReactDOM.render(<TodoComp />,document.getElementById('myList'));

3个回答

您需要使用 refs 从父组件调用子组件中的函数

将父级的 List 组件渲染为

<List ref="myList"/>

然后访问该handleNewText()功能this.refs.myList.handleNewText()

更新:

React 不再推荐字符串引用,你应该使用引用回调,检查这个

<List ref={(ref) => this.myList=ref}/>

然后访问子功能,如

this.myList.handleNewText()

添加到@shubham-khatri 解决方案:

如果您正在引用连接的子组件...

一个。那个孩子必须withRef: true在(第 4 个)配置参数中说:

@connect(store => ({
    foo: store.whatever
    …
}),null,null,{ withRef: true })

访问是通过getWrappedInstance()(注意,getWrappedInstance也需要调用()

getWrappedInstance().howdyPartner()

当函数式组件出现时,我开始学习 React。我尝试了一些成功的另一种方法是返回您想要作为 JSON 中的闭包访问的函数。我喜欢这种方法,因为闭包是 Javascript 的一种构造,即使 React 再次更新它也应该仍然有效。下面是一个子组件的例子

function Child(){
    //declare your states and use effects
    const [ppp, setPPP] = useState([]);
    const [qqq, setQQQ] = useState(2);
    //declare function that you want to access
    function funcA(){ /*function to interact with your child components*/}
    function funcB(){ /*function to interact with your child components*/}

    //pure React functional components here
    function Content(){
         //function that you cannot access
         funcC(){ /*.....*/}
         funcD(){/*.......*/}
         //what to render
         return (
           <div> 
               {/* your contents here */} 
           </div>
         )
    }
    //return accessible contents and functions in a JSON
    return {
        content: Content, //function for rendering content
        ExposeA: funcA,   //return as a closure
        ExposeB: funcB,   //return as a closure
    }
}

下面是如何在父级中呈现子级内容的示例

function Parent(){
    let chi = Child();
    let ChildContent = chi.Content;
    //calling your exposed functions
    //these function can interacts with the states that affects child components
    chi.ExposeA();  
    chi.ExposeB();
    //render your child component
    return (<div>
        <div> {/* parent stuff here */</div>
        <div> {/* parent stuff here */</div>
        <ChildContent {/*Define your props here */} />
    </div>)
}