如何获取数据以与Redux反应

时间:2020-03-23 17:03:31

标签: reactjs redux react-redux fetch-api react-lifecycle-hooks

我不明白为什么我首先会得到未定义的信息,然后再获得正确的数据,也因为我在componentDidMount()中得到的信息未定义,所以我无法在此处收集数据,所以如果有人知道如何解决此问题,请帮助我,我也使用redux-dev-tools,在那里我得到正确的数据,但是在控制台上,我得到的数据是我在下面写的

action.js

import * as actionTypes from '../actions/actionTypes';

export const fetchToursSuccess = ( tours ) => {
    return {
        type: actionTypes.FETCH_TOURS_SUCCESS,
        tours: tours
    };
};

export const fetchToursFail = ( error ) => {
    return {
        type: actionTypes.FETCH_TOURS_FAIL,
        error: error
    };
};

export const fetchToursStart = () => {
    return {
        type: actionTypes.FETCH_TOURS_START
    };
};


export const fetchTours = () => {
    return dispatch => {
        dispatch(fetchToursStart());
            fetch('http://localhost:5000/api/v1/tours')
            .then(response => {
                if (response.status !== 200) {
                  throw new Error('Failed to fetch tours.');
                }
                return response.json();
            })
            .then( resData => {
                const fetchedTours = [];
                for ( let key in resData.data.data ) {
                    fetchedTours.push( {
                        ...resData.data.data[key],
                        id: key
                    } );
                }
                console.log(fetchedTours);
                dispatch(fetchToursSuccess(fetchedTours));
            } )
            .catch( err => {
                dispatch(fetchToursFail(err));
            });
    };
};

reducer.js

import * as actionTypes from '../actions/actionTypes';
import { updateObject } from '../utility';

const initialState = {
    tours: [],
    loading: false,
    isLoaded: false,
};

const fetchToursStart = ( state, action ) => {
    return updateObject( state, { loading: true } );
};

const fetchToursSuccess = ( state, action ) => {
    return updateObject( state, {
        loading: false,
        isLoaded: true,
        tours: action.tours

    } );
};

const fetchToursFail = ( state, action ) => {
    return updateObject( state, { loading: false } );
};

const reducer = ( state = initialState, action ) => {
    switch ( action.type ) {
        case actionTypes.FETCH_TOURS_START: return fetchToursStart( state, action );
        case actionTypes.FETCH_TOURS_SUCCESS: return fetchToursSuccess( state, action );
        case actionTypes.FETCH_TOURS_FAIL: return fetchToursFail( state, action );
        default: return state;
    }
};

export default reducer;

Component Overview.js

import React, { Component } from 'react';
import { connect } from 'react-redux';
import PropTypes from 'prop-types';

// import axios from '../../axios-orders';

import * as actions from '../store/actions/index';
import { fetchTours } from '../store/actions/tour';

class Overview extends Component {
    componentDidMount () {
        console.log( this.props.onFetchTours());
        console.log( this.props.tours);
    }

    render () {
        if ( this.props.loading ) {
            console.log('Loading..........');
        }


        return (
            <div>
                hello from Overview
            </div>
        );
    }
}

const mapStateToProps = state => {
    return {
      tours: state.tours,
      loading: state.loading,
      isLoaded: state.isLoaded

    };
  };

const mapDispatchToProps = dispatch => {
    return {
        onFetchTours: () => dispatch( actions.fetchTours() )
    };
};


export default connect( mapStateToProps, mapDispatchToProps )( Overview );

我得到下一个结果,

Overview.js:12 undefined
Overview.js:13 []
Overview.js:49 Loading..........
tour.js:131 (9) [{…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}]
Overview.js:53 (9) [{…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}]

0 个答案:

没有答案