我正在尝试使用 redux 存储从 API 中检索一组产品。为了实现这一点,我创建了 actions 和 reducers,一个 functionmapStateToProps()和一个 function mapDispatchToProps(),后者包含一个 function fetchProducts(),它在动作文件中定义并且在调用时应该检索产品列表。所有这些都是通过以下方式完成的:这是概览组件,它应该渲染数据(实际渲染被省略了,因为它不影响这个问题):import React, {Component} from 'react';import {connect} from 'react-redux';import PropTypes from 'prop-types'import fetchProductsAction from '../actions/ProductFetchingActionFile'import {bindActionCreators} from 'redux';export class Overview extends Component { constructor(props) { super(props); } componentDidMount() { this.props.fetchProducts(); } render() { return( <h1>test</h1> ) }}const mapStateToProps = state => ({ error: state.rootReducer.productsReducer.error, products: state.rootReducer.productsReducer.products, pending: state.rootReducer.productsReducer.pending,})const mapDispatchToProps = dispatch => bindActionCreators({ fetchProducts: fetchProductsAction }, dispatch)Overview.propTypes = { fetchProducts: PropTypes.func}export default connect(mapStateToProps, mapDispatchToProps)(Overview);这是操作文件 (ProductFetchingActionFile):import { PREFIX, FETCH_PRODUCTS_PENDING, FETCH_PRODUCTS_SUCCESS, FETCH_PRODUCTS_ERROR} from "./types";function fetchProductsPending() { return{ type: FETCH_PRODUCTS_PENDING }}function fetchProductsSuccess(products) { return{ type: FETCH_PRODUCTS_SUCCESS, products: products }}function fetchProductsError(error) { return{ type: FETCH_PRODUCTS_ERROR, error: error }}
2 回答
data:image/s3,"s3://crabby-images/11d13/11d13ce15305b0d0c303315400a5b28e40b246f5" alt="?"
慕斯王
TA贡献1864条经验 获得超2个赞
试试这个
const mapDispatchToProps = dispatch => {
fetchProducts : () => {
dispatch(fethcProducts())
}
}
data:image/s3,"s3://crabby-images/a6e4a/a6e4a76d83eb33e32a06873b0c20d5acb6d326c8" alt="?"
慕哥6287543
TA贡献1831条经验 获得超10个赞
您正在将您的操作导入为
import fetchProductsAction from '../actions/ProductFetchingActionFile'
当它看起来没有作为默认值导出时。
大概应该是:
import { fetchProductsAction } from '../actions/ProductFetchingActionFile'
添加回答
举报
0/150
提交
取消