react兄弟组件通信,类组件向函数组件通信

/* eslint-disable react/jsx-indent */
/* eslint-disable import/named */
import React from 'react';
import Top from './top';
import Left from './left';

import Content from './conent';
import './c.less';
class Main extends React.Component {
  constructor(props) {
    super(props);

    this.state = {
      leftcheck: false,
    };
  }
  getChildrenMsg = (result, msg) => {
    this.setState({
      leftcheck: msg,
    });
  };
  render() {
    const { leftcheck } = this.state;
    const topprops = {};

    const leftprops = {
      leftcheck,
      left: 1,
    };

    const contprops = {};
    return (
      <div className="bb">
        <div className="top">
          <Top {...topprops} />
        </div>
        <div className="zz">
          <div className="left">
            <Left parent={this} />
          </div>
          <div className="content">
            <Content xdinfo={leftprops} />
          </div>
        </div>
      </div>
    );
  }
}
export default Main;
/* eslint-disable react/jsx-indent */
/* eslint-disable import/named */
import { CheckBox } from 'choerodon-ui/pro';
import React from 'react';

class Left extends React.Component {
  constructor(props) {
    super(props);
    const { leftcheck, left } = props;
    console.log(left, leftcheck, 'left');
    /**
     * 内部状态
     */
    this.state = {};
  }

  render() {
    const toParent = () => {
      // console.log(this.props.parent.getChildrenMsg.bind(this, this.state.msg))
      this.props.parent.getChildrenMsg(this, this.state.msg);
    };
    const handleChange = val => {
      console.log(val);
      this.props.parent.getChildrenMsg(this, val);

      // toParent(val);
    };
    return (
      <div>
        <CheckBox name="base" onChange={handleChange}>
          A
        </CheckBox>
      </div>
    );
  }
}
export default Left;


import React from 'react';

const content = props => {
  const { xdinfo } = props;

  return <div>{xdinfo.leftcheck ? 1111 : 2222}</div>;
};
export default content;```

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值