gpt4 book ai didi

javascript - Fetch 为空 Redux Saga

转载 作者:行者123 更新时间:2023-11-30 11:19:42 26 4
gpt4 key购买 nike

我 5 分钟前才开始学习 Redux Saga

我的传奇:

import axios from "axios";
import {call, put, takeLatest} from "redux-saga/effects";
import {
USERS_FETCH_REQUESTED,
USERS_FETCH_SUCCEEDED,
USERS_FETCH_FAILED
} from 'actions/constants'

function *fetchUsers(action) {
try {
const response = yield call(fetch, 'https://jsonplaceholder.typicode.com/users');
const data = response.json();
console.log(data)
yield put({type: USERS_FETCH_SUCCEEDED, payload: data});
} catch (e) {
yield put({type: USERS_FETCH_FAILED, payload: e.message});
}
}

function* mySaga() {
yield takeLatest(USERS_FETCH_REQUESTED, fetchUsers);
}

export default mySaga

出于某种原因,我的 SUCCES_FETCH 的有效负载只是一个空对象,但日志返回 10 10 个项目。

我做错了什么?

最佳答案

response.json() 返回一个 promise,您需要等待 promise 解析才能获取项目。

const data = yield call([response, 'json']);

这将产生一个调用 response.json() 的效果,并在 promise 解析后将结果反馈到 saga 中。

关于javascript - Fetch 为空 Redux Saga,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50276291/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com