У меня есть приложение React-Redux, и у меня проблема с обещанием. Для начала я хотел бы дать вам мой код:
проблема в том, что мой dateApi просто «удивителен» во второй раз. Мне нужно дать обещание, но я не знаю, как это сделать.
ПРОБЛЕМА: это мой метод в программе переднего плана:
...
this.props.handleLastWeek(this.props.dateFrom, this.props.dateTo);
// ^^ this returns dataApi ^^
var i = 1;
var j = 1;
var k = 1;
var l = 0;
var dateArray = [];
this.props.dataApi.map(dA => {
... // this.props.dataApi is null
Разбавление:
case GET_DATA_LAST_WEEK:
return state.set("dataApi", []).set("isLoading", true);
case GET_DATA_LAST_WEEK_SUCCESS:
return state.set("isLoading", false).set("dataApi", action.response);
Это мои действия: (ответ - мои dataApi)
export function getDataLastWeekAction(from, to) {
return {
type: GET_DATA_LAST_WEEK,
from,
to
};
}
export function successDataLastWeekAction(response) {
return {
type: GET_DATA_LAST_WEEK_SUCCESS,
response
};
}
А это моя функция излишней саги:
export function* handleLastWeek() {
const from = yield select(makeSelectDateFrom());
const to = yield select(makeSelectDateTo());
const requestURL = `/api/daydate`;
try {
const response = yield call(request, requestURL, {
method: "POST",
headers: {
Authorization: `Bearer ${getToken()}`,
Accept: "application/json",
"Content-Type": "application/json"
},
body: JSON.stringify({
from,
to
})
});
if (response) {
yield put(successDataLastWeekAction(response));
} else {
yield put(errorDataLastWeekAction("Spróbuj ponownie za moment."));
}
} catch (err) {
yield put(errorDataLastWeekAction(err));
}
}