我想调用另一个组件的方法

时间:2019-04-22 10:37:39

标签: javascript reactjs react-native

我的组件AddPost.js使用machine.js中存在的机器,在上一个文件中,我想调用AddPost中存在的方法,我试图导入AddPost,但是它不起作用。 我有一个错误:可能的未处理的承诺拒绝(id:0): ReferenceError:未定义addInBubble 我想知道如何在machine.js中调用此方法,因为我在此文件中有操作,并且将在操作中调用此方法

AddPost.js

import React, {PureComponent} from 'react';
import {View, Text, TextInput,ScrollView,StyleSheet} from 'react-native';
import {Button,Input,Bubble,ThemeProvider} from 'nachos-ui';
import {Navigation} from 'react-native-navigation';
import PropTypes from 'prop-types';
import {fetchMachine} from '../../helpers/machine.js';

console.disableYellowBox = true;
const styles = StyleSheet.create({
  container :{ 
    marginVertical:15 , flex: 1,
    flexDirection: 'column',
  },
  ButtonView : {
    flex: 1, 
    flexDirection: 'row',
    position: 'absolute',
    bottom:0,

  },
  bubbleStyle:{
     marginBottom: 15,
     marginLeft: 20,
     width: '80%'

    }
});

  let currentState = fetchMachine.initialState;
  let valuesCurrentState = currentState.nextEvents;
class AddPost extends PureComponent {

  static propTypes = {
    componentId: PropTypes.string,
    text:PropTypes.string
  }

  constructor(props) {
    super(props);
    this.state = {
      responseValue :[],
      value1 : 'Yes',
      value2 : 'No',
      value : ''

    };
  }


  addInBubble = () =>{
    let newValue = this.state.value;
    this.setState({      
      responseValue : [...this.state.responseValue,newValue]
    });
  }

  render() {

    let newArray = this.state.responseValue && this.state.responseValue.map(( item, key ) =>{
      return(
        <View key = { key } >
            <Bubble style = { styles.bubbleStyle }> { item }</Bubble>
        </View>
    );
    });
    return (

         <ThemeProvider>
        <View style={styles.container}>
        <ScrollView >
                <View style = {{ flex: 1, padding: 4 }}>
                {
                    newArray
                }
                </View>
        </ScrollView>
          <View style={styles.ButtonView}>
          <Button
              onPress = {this.addInBubble} 
          >
            {this.state.value1}
          </Button>
          <Button
              onPress = {this.addInBubble} 
          >
            {this.state.value2}
          </Button>
          </View>

        </View>
      </ThemeProvider>
    );
  }
}
export default AddPost;

machine.js

import { Machine, actions } from 'xstate';
import {AddPost} from '../screens/Summary/AddPost';

const fetchMachine = Machine({
  id: 'Hands Free',
  context: { attempts: 0},
  initial: 'summary',
  states: {
    summary: {
      on: {
          yes: {
            target: 'prioritization',
            actions: ['activate', 'sendTelemetry']
          },
        no : 'readMails'
      }
    },
    prioritization: {
      on: {
        read: 'readByPrioritization',
        skip: 'readMails'
      }
    },
    readByPrioritization: {

          on: {
        read: 'readMails',
        skip: 'listener'
      }

    },
    readMails: {
      on: {
        next: 'readMails',
        skip: 'listener'
      }
    },
    listener: {

      on: {
        received: 'readSummary',
        notyet: 'listener'
      }
    },
    readSummary: {

      on: {
        read: 'readEmail',
        skip :'listener'
      }
    },
    readEmail: {

      on: {
        finish: 'listener',
      }
    }
  }
},
  {
    actions: {
      // action implementations
      activate: (context, event) => {
        console.log('activating...');
          AddPost.addInBubble(); // this the methode that i want to call
        return 0;
      },
      notifyActive: (context, event) => {
        console.log('active!');
      },
      notifyInactive: (context, event) => {
        console.log('inactive!');
      },
      sendTelemetry: (context, event) => {
        console.log('time:', Date.now());
      }
    }
  });

  export{fetchMachine};

I want to call the method addInBubble but I have an error

1 个答案:

答案 0 :(得分:3)

您可以将parent方法作为道具传递给child组件以进行访问

Class A extends Component {
  addInBubble = () => {
    // Some logic here
  }

  render() {
    <B addInBubble={this.addInBubble} />
  }

}

因此可在组件B中访问

Class B extends Component {

  render() {
    <div onClick={this.props.addInBubble} />
  }

}