首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在react中使用Redux工具包的createEntityAdapter时出错

在react中使用Redux工具包的createEntityAdapter时出错
EN

Stack Overflow用户
提问于 2020-07-27 12:12:28
回答 1查看 262关注 0票数 0

我在使用ReduxToolkit错误的对象时遇到了问题: TypeError: createEntityAdapter (...)不是函数

供应商切片:从'@reduxjs/toolkit‘导入{ createSlice,createAsyncThunk,createEntityAdapter }从' axios’导入axios

代码语言:javascript
复制
export const getSupplierData = createAsyncThunk(
    'supplier/getSupplierData', async () => {
        const response = axios.get(
        "http://127.0.0.1:8000/supplier/"
        );
        const data = await (await response).data
        return data
    })

const suppliersAdapter = createEntityAdapter({})


export const { selectAll:selectSuppliers} = suppliersAdapter.getSelectors(
    state=>state.suppliers
)


export const supplierSlice = createSlice({
    name: 'supplier',
    initialState:suppliersAdapter.getInitialState({}),
    reducers: {},
    extraReducers: {
        [getSupplierData.fulfilled]:(state,action)=>action.payload
    }
})


export default supplierSlice.reducer

supplier.js

代码语言:javascript
复制
import { useDispatch } from 'react-redux'
import { getSupplierData,selectSuppliers} from './SupplierSlice'
const dispatch = useDispatch()
const classes = useStyles();
useEffect(() => {
   dispatch(getSupplierData()) 
}, [])
const suppliers = useSelector(selectSuppliers)
console.log(suppliers)
EN

回答 1

Stack Overflow用户

发布于 2020-12-02 17:41:38

如下所示更改您的代码:

代码语言:javascript
复制
export const getSupplierData = createAsyncThunk(
    'supplier/getSupplierData', async () => {
        const response = await axios.get(
        "http://127.0.0.1:8000/supplier/"
        );
        const data = await response.data;
        return data
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63108607

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档