React Native - 渲染没有返回任何内容

React Native - Nothing was returned from render

我的应用程序存储在 /src/index.js 但我也有一个 /App.js 和一个 /index.js.

我不知道它们之间的区别,我认为这就是我收到此错误的原因。

/index.js

import { AppRegistry } from 'react-native';
import App from './App';
AppRegistry.registerComponent('client', () => App);

/App.js

import App from './src/index';

export default App;

/src/index.js

import React from 'react';
import { AppRegistry } from 'react-native';
import { Provider, connect } from 'react-redux';
import { addNavigationHelpers } from 'react-navigation';

import Navigator from './routes/route';
import store from './store/configureStore';


const App = ({ dispatch, nav }) => {

    <Navigator
        navigation={addNavigationHelpers({
            dispatch,
            state: nav,
        })}
    />
};

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



const AppWithNavigation = connect(mapStateToProps)(App);

export default () => {

    <Provider store={store}>
        <AppWithNavigation />
    </Provider>

}

我使用 create react native package 来构建这个项目,然后尝试遵循一些指南来使用 redux 实现 react 导航。

您的默认导出没有 returning 任何内容 :

export default () => {

    <Provider store={store}>
        <AppWithNavigation />
    </Provider>

}

为了 return 带有箭头函数的 JSX,您需要使用 () => ( <JSX /> ) 或带花括号的等效函数:() => { return ( <JSX /> ) } :

export default () => (    
    <Provider store={store}>
        <AppWithNavigation />
    </Provider>
)

或:

export default () => {
    return (    
       <Provider store={store}>
           <AppWithNavigation />
       </Provider>
   )
}

您忘记了 return components

const App = ({ dispatch, nav }) => {
    return(
        <Navigator
            navigation={addNavigationHelpers({
                dispatch,
                state: nav,
            })}
        />
    )
};


export default () => {
    return(
        <Provider store={store}>
            <AppWithNavigation />
        </Provider>
    )
}

我没有提到这个

import React from 'react';

以及我的其他屏幕文件中的所有其他 react-native 组件。

因为我是从另一个文件调用我的屏幕组件,从 App.js 文件,所以我也必须在该文件中导入 react 和 react-native 组件。