Реагируйте на встроенную навигацию с Redux: response-navigation-redux-helpers - 'undefined не является объектом (оценка state.routes)' - PullRequest
0 голосов
/ 13 января 2019

Я пытаюсь реализовать редукцию и навигацию в собственном приложении реакции, поэтому я пытаюсь следовать инструкциям для реактивных помощников реагирования ( здесь ).

Однако при попытке запустить приложение я получаю следующую ошибку:

Error

App.js:

import React from 'react';
import { StyleSheet, Text, View } from 'react-native';
import { createStore, combineReducers, applyMiddleware } from 'redux';
import { Provider, connect } from 'react-redux';
import rootReducer from './src/reducers/index';
import { createStackNavigator, createAppContainer } from 'react-navigation';
import { reduxifyNavigator, createReactNavigationReduxMiddleware, createNavigationReducer } from 'react-navigation-redux-helpers';

import LoginScreen from './src/screens/LoginScreen';
import NotesScreen from './src/screens/NotesScreen';

const AppNavigator = createStackNavigator({
  Login: {
        screen: LoginScreen
  },
  Notes: {
        screen: NotesScreen
  }
})

const navReducer = createNavigationReducer(AppNavigator);

const appReducer = combineReducers({
  rootReducer,
  navReducer
})

const middleware = createReactNavigationReduxMiddleware('Login', state => state.nav);

const App = reduxifyNavigator(AppNavigator, 'Login');

const mapStateToProps = state => ({
  state: state.nav
})

const AppWithNavigationState = connect(mapStateToProps)(App);

const store = createStore(appReducer, applyMiddleware(middleware));

export default class Root extends React.Component {
  render() {
        return (
              <Provider store={store}>
                    <AppWithNavigationState />
              </Provider>
        )
  }
}

1 Ответ

0 голосов
/ 14 июня 2019

попробуйте реализовать свой код, как указано в документации, даже с именами. Это действительно должно работать, и в вашем случае это следующее:


    //delete
import { reduxifyNavigator, ...} from 'react-navigation-redux-helpers';
//add 
import { createReduxContainer } from 'react-navigation-redux-helpers';

const AppNavigator = createStackNavigator({
    Login: {
          screen: LoginScreen
    },
    Notes: {
          screen: NotesScreen
    }
  })

  const navReducer = createNavigationReducer(AppNavigator);

  const appReducer = combineReducers({
    rootReducer,
    nav : navReducer
  })

  const middleware = createReactNavigationReduxMiddleware(state => state.nav);

  const App = createReduxContainer(AppNavigator);

  const mapStateToProps = state => ({
    state: state.nav
  })

  const AppWithNavigationState = connect(mapStateToProps)(App);

  const store = createStore(appReducer, applyMiddleware(middleware));

  export default class Root extends React.Component {
    render() {
          return (
                <Provider store={store}>
                      <AppWithNavigationState />
                </Provider>
          )
    }
  }

...