Passing props to react-redux container component

后端 未结 4 1739
温柔的废话
温柔的废话 2021-01-30 05:08

I have a react-redux container component that is created within a React Native Navigator component. I want to be able to pass the navigator as a prop to this container component

4条回答
  •  无人及你
    2021-01-30 05:38

    There's a few gotchas when doing this with typescript, so here's an example.

    One gotcha was when you are only using dispatchToProps (and not mapping any state props), it's important to not omit the state param, (it can be named with an underscore prefix).

    Another gotcha was that the ownProps param had to be typed using an interface containing only the passed props - this can be achieved by splitting your props interface into two interfaces, e.g.

    interface MyComponentOwnProps {
      value: number;
    }
    
    interface MyComponentConnectedProps {
      someAction: (x: number) => void;
    }
    
    export class MyComponent extends React.Component<
      MyComponentOwnProps & MyComponentConnectedProps
    > {
    ....//  component logic
    }
    
    const mapStateToProps = (
      _state: AppState,
      ownProps: MyComponentOwnProps,
    ) => ({
      value: ownProps.value,
    });
    
    const mapDispatchToProps = {
      someAction,
    };
    
    export default connect(mapStateToProps, mapDispatchToProps)(MyComponent);
    

    The component can be declared by passing the single parameter:

    
    

提交回复
热议问题