reactjs - React Redux 在动作创建者上操作原始数据
问题描述
在我的 React Redux 应用程序中,我从我的 action creator 上的 API 接收原始数据,然后我在将带有精炼数据的 action 分派到 Reducer 之前对其进行进一步操作。但是,在运行时,代码似乎永远不会指向将操作分派给减速器,因为我尝试记录文本并且它从未出现在控制台上。我错过了什么?我很感激任何帮助。下面的相关动作创建者代码...
export const getTrainerAvailability = (trainerId) => {
console.log('getting here', trainerId)
return async (dispatch) => {
dispatch(getTrainerAvailabilityRequest());
const token = await AsyncStorage.getItem('token');
fetch(url + 'gettraineravailability/' + trainerId, {
method: 'GET',
headers: {
'Content-Type': 'application/json',
'Authorization': `${token}`
}
})
.then(res => res.json())
.then(res => {
console.log('RES', res) // <-- logs as expected
if (res.error) {
console.log('error')
throw(res.error);
}
dispatch(getTrainerAvailabilitySuccess(res));
})
.catch(error => {
dispatch(getTrainerAvailabilityError(error));
})
}
};
export const getTrainerAvailabilitySuccess = (data) => {
console.log('RAW DATA: ', data[0]) // <-- this is logged as expected
const rawAvailability = data[0]
let mondayAvailability = [];
let tuesdayAvailability = [];
let wednesdayAvailability = [];
let thursdayAvailability = [];
let fridayAvailability = [];
let saturdayAvailability = [];
let sundayAvailability = [];
for (let item of rawAvailability) {
if (item.week_day === 'Monday') {
mondayAvailability.push(item);
}
else if (item.week_day === 'Tuesday') {
tuesdayAvailability.push(item);
}
else if (item.week_day === 'Wednesday') {
wednesdayAvailability.push(item);
}
else if (item.week_day === 'Thursday') {
thursdayAvailability.push(item);
}
else if (item.week_day === 'Friday') {
fridayAvailability.push(item);
}
else if (item.week_day === 'Saturday') {
saturdayAvailability.push(item);
}
else if (item.week_day === 'Sunday') {
sundayAvailability.push(item);
}
}
console.log('im here', mondayAvailability) // this is not logged
const interval = moment.duration(30, 'minutes');
let startTime;
let endTime
let arrayLength;
let slotTime;
let refinedData;
// further array manipulation...
console.log('REFINED DATA: ', refinedData) // <- this is not logged
return {
type: 'GET_TRAINER_AVAILABILITY_SUCCESS',
payload: refinedData
}
};
解决方案
这不是一个真正的答案,但我不能轻易地在评论中发布它。
1)添加一些日志中间件,这样你就可以看到发生了什么。我的是这样的:
const logger = store => next => action => {
//LOTS OF LOGGING
//console.log('[DISPATCHING] %s', action.type, JSON.stringify(action) )
//SOME LOGGING
console.log('[DISPATCHING] %s', action.type)
const result = next(action)
console.log('[NEXT STATE]', store.getState())
return result
}
2) 如果您正在使用一组异步操作(例如等待/重试获取),您可能需要查看redux-saga
. 它基本上是为处理异步工作流而构建的。
3)这不是一个完整的例子,所以我不能给你任何关于其他问题点的反馈。缺少方法getTrainerAvailabilityRequest
,getTrainerAvailabilityError
例如
4)添加更多日志,如果您无法附加调试器,这是调试它的最佳方法。另外,您是否使用调试器?如果您使用源映射构建,Chrome 开发工具工作得很好。如果没有,请放入大量日志语句。你会弄清楚挂的是什么。您的成功方法也很有可能出现错误。我肯定会在其中放置一条日志记录行,for loop
以确保它实际上正在运行和退出。您正在处理来自 fetch 调用的数据,这始终是一个失败点。
以及不那么自以为是的东西......
我在这里看到的问题是:
for (let item of rawAvailability) {
什么是rawAvailability
?它实际上是一个数组吗?
基本上我会试试这个:
for (let item of rawAvailability) {
console.log(`[DEBUG]`, JSON.stringify(item, null, 2) );
if (item.week_day === 'Monday') {
mondayAvailability.push(item);
}
else if (item.week_day === 'Tuesday') {
tuesdayAvailability.push(item);
}
else if (item.week_day === 'Wednesday') {
wednesdayAvailability.push(item);
}
else if (item.week_day === 'Thursday') {
thursdayAvailability.push(item);
}
else if (item.week_day === 'Friday') {
fridayAvailability.push(item);
}
else if (item.week_day === 'Saturday') {
saturdayAvailability.push(item);
}
else if (item.week_day === 'Sunday') {
sundayAvailability.push(item);
} else {
console.log(`[INVALID_ITEM]`, JSON.stringify(item, null, 2) );
}
}
根据您的设置,redux
可能不会显示引发的错误。添加日志记录以便您可以查看所有操作和数据以及在可能的故障点内进行日志记录应该向您显示问题。
祝你好运!这不是一个真正的答案,这只是我将如何处理它。
推荐阅读
- java - 有意来电——避免给自己打电话
- r - 对数据进行子集化时,在多条黄土平滑线上应用全范围选项
- javascript - 无法使用 javascript 更改图像 src
- corda - 我们没有为以下交易参与者提供流会话 - Corda 4
- sql - 使用窗口函数查询的最佳索引
- python - 运行 Flask 应用程序中的致命 Stackoverflow
- ios - iOS12,kReachabilityChangedNotification 不起作用
- magento - Magento 2 Authorize.net DPM PCI 合规性
- laravel - 如何重定向到带有标题的外部 url?
- vb.net - 应用程序设置数据集 - 颜色列不保存