ReactJS - 从另一个组件调用一个组件方法

ReactJS - Call One Component Method From Another Component

我有两个组成部分。我想从第二个组件调用第一个组件的方法。我该怎么做?

这是我的代码。

第一个组件

class Header extends React.Component{

    constructor(){
        super();
    }

    checkClick(e, notyId){
       alert(notyId);
    }
}

export default Header;

第二个组件

class PopupOver extends React.Component{

    constructor(){
        super();
        // here i need to call Header class function check click....
        // How to call Header.checkClick() from this class
    }

    render(){
        return (
            <div className="displayinline col-md-12 ">
                Hello
            </div>
        );
    }
}

export default PopupOver;

嗯,实际上,React 不适合从父级调用子方法。一些框架,如 Cycle.js,允许轻松访问父子数据,并对其做出反应。

此外,您很可能并不真正需要它。考虑将其调用到现有组件中,它是更独立的解决方案。但有时你仍然需要它,然后你的选择就很少了:

  • 向下传递方法,如果是child(最简单的,也是传递的属性之一)
  • 添加事件库;在 React 生态系统中,Flux 方法是最著名的,具有 Redux 库。您将所有事件分离为独立的状态和动作,并从组件
  • 中分派它们
  • 如果您需要在父组件中使用子组件的功能,您可以包裹在第三个组件中,并使用增强的 props 克隆父组件。

UPD:如果您需要共享一些不涉及任何状态的功能(如 OOP 中的静态函数),则无需将其包含在组件中。单独声明,需要时调用即可:

let counter = 0;
function handleInstantiate() {
   counter++;
}

constructor(props) {
   super(props);
   handleInstantiate();
}

你可以这样做

import React from 'react';

class Header extends React.Component {

constructor() {
    super();
}

checkClick(e, notyId) {
    alert(notyId);
}

render() {
    return (
        <PopupOver func ={this.checkClick } />
    )
}
};

class PopupOver extends React.Component {

constructor(props) {
    super(props);
    this.props.func(this, 1234);
}

render() {
    return (
        <div className="displayinline col-md-12 ">
            Hello
        </div>
    );
}
}

export default Header;

使用静力学

var MyComponent = React.createClass({
 statics: {
 customMethod: function(foo) {
  return foo === 'bar';
  }
 },
   render: function() {
 }
});

MyComponent.customMethod('bar');  // true