将useEffect与React-redux一起使用

时间:2020-05-31 18:29:02

标签: reactjs react-redux react-hooks

我有问题。据我了解,钩子useEffect不会运行。 我已采取措施应从服务器获取数据。

export const getProducts = () => {
    return dispatch => {
        dispatch(getProductsStarted());

        fetch('https://shopserver.firebaseapp.com/get-products')
            .then(res => {
                dispatch(getProductsSuccess(res.json()));
            })
            .catch(err => {
                dispatch(getProductsFailure(err.message));
            });
    }
}

const getProductsSuccess = todo => ({
    type: "ADD_TODO_SUCCESS",
    payload: {
        ...todo
    }
});

const getProductsStarted = () => ({
    type: "ADD_TODO_STARTED"
});

const getProductsFailure = error => ({
    type: "ADD_TODO_FAILURE",
    payload: {
        error
    }
});

我有一个减速器。

const initialState = {
    loading: false,
    products: [],
    error: null
}

export const ProductReducer = (state = initialState, action) => {
    switch (action.type) {
        case "ADD_TODO_SUCCESS":
            return {
                ...state,
                loading: false,
                error: null,
                todos: [...state.products, action.payload.products]
            }
        case "ADD_TODO_STARTED":
            return {
                ...state,
                loading: true
            }
        case "ADD_TODO_FAILURE":
            return {
                ...state,
                loading: false,
                error: action.payload.error
            }
        default:
            return state
    }
}

我有一个要在其中呈现结果的组件。

import React from 'react';
import { CardItem } from "./cardItem";
import { useSelector } from 'react-redux';
import { useEffect } from 'react';
import { getProducts } from '../Redux/Actions/productAction'

export const ProductCard = () => {

    useEffect(() => {
        getProducts();
        console.log('111111')
    })

    const data = useSelector(state => state.ProductReducer.products);

    return (
        <div>
            {data.map( element =>
                CardItem (element)
            )}
        </div>
    )
}

呈现页面后,没有任何反应。 ReduxDevTools显示没有发送动作。请帮我修复它。谢谢。

1 个答案:

答案 0 :(得分:0)

我认为您应该像这样调用异步操作:

import { useDispatch, useSelector } from 'react-redux';

[...]

export const ProductCard = () => {

  const dispatch = useDispatch();

  useEffect(() => {
      // I guess getProducts is an async redux action using redux-thunk
      dispatch(getProducts());
      console.log('111111')
  }, []);

  [...]

}

我假设您只想在组件诞生时才加载产品,所以我将一个空数组作为useEffect(https://reactjs.org/docs/hooks-reference.html#useeffect)的第二个参数传递。