我用占位符函数填写了您丢失的代码,它对我有用 - 我的有效负载最终包含一个解析为返回值的承诺toItemDetails
。因此,也许这是您未在此处包含的代码中的某些内容。
function getItem(id) {
return Promise.resolve({
attr1: 'hello',
data: 'data inside item',
tagIds: [1, 3, 5]
});
}
function getTags(tagIds) {
return Promise.resolve({ data: 'abc' });
}
function toItemDetails(tagData, itemData) {
return { itemDetails: { tagData, itemData } };
}
function fetchTagsForItem(id = null) {
let itemFromAxios;
return {
type: 'FETCH_ITEM_INFO',
payload: getItem(id)
.then(item => {
itemFromAxios = item;
return getTags(item.tagIds);
})
.then(tags => toItemDetails(tags.data, itemFromAxios.data))
};
}
const action = fetchTagsForItem(1);
action.payload.then(result => {
console.log(`result: ${JSON.stringify(result)}`);
});
输出:
result: {"itemDetails":{"tagData":"abc","itemData":"data inside item"}}
为了item
在第二步中进行访问,您需要将其存储在一个在函数作用域中声明的变量中fetchTagsForItem
,因为这两个.then
s 本质上是兄弟姐妹:两者都可以访问封闭作用域,但第二次调用.then
won' t 可以访问在第一个声明中声明的变量。
关注点分离
创建您发送到 Redux 的操作的代码也会进行多次 Axios 调用并处理返回的数据。这使得阅读和理解变得更加复杂,并且使处理 Axios 调用中的错误等事情变得更加困难。我建议把事情分开。一种选择:
- 将任何调用axios的代码放在自己的函数中
- 设置
payload
为该函数的返回值。
- 将该函数以及所有其他调用 Axios 的函数移动到一个单独的文件(或一组文件)中。该文件成为您的 API 客户端。
这看起来像:
// apiclient.js
const BASE_URL = 'https://yourapiserver.com/';
const makeUrl = (relativeUrl) => BASE_URL + relativeUrl;
function getItemById(id) {
return axios.get(makeUrl(GET_ITEM_URL) + id);
}
function fetchTagsForItemWithId(id) {
...
}
// Other client calls and helper funcs here
export default {
fetchTagsForItemWithId
};
您的操作文件:
// items-actions.js
import ApiClient from './api-client';
function fetchItemTags(id) {
const itemInfoPromise = ApiClient.fetchTagsForItemWithId(id);
return {
type: 'FETCH_ITEM_INFO',
payload: itemInfoPromise
};
}