20.01.26 21:44 작성
·
239
3
강의에서 axios 요청이 너무 빨라서 뜨지 않는다라고 설명해주셨는데, 이부분은이 잘못된거 같습니다.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then
// using a resolved promise, the 'then' block will be triggered instantly,
// but its handlers will be triggered asynchronously as demonstrated by the console.logs
const resolvedProm = Promise.resolve(33);
let thenProm = resolvedProm.then(value => {
console.log("this gets called after the end of the main stack. the value received and returned is: " + value);
return value;
});
// instantly logging the value of thenProm
console.log(thenProm);
mdn의 설명을 보면, promise가 resolve 된 이후, then() 메서드 안의 핸들러는 비동기적으로 호출 된다고 설명하고 있습니다.
(복사붙여 넣기를 하니 포맷이 이상해져서 읽기 불편한점 죄송합니다)
그래서 테스트를 해보았습니다.
//views/NewsView.vue
created() {
bus.$emit("start:spinner");
// setTimeout(() => {
// }, 3000);
this.$store.dispatch("FETCH_NEWS")
.then(result => {
bus.$emit("end:spinner");
console.log("result");
console.log(result);
return result;
})
.catch(err => {
console.error(err);
});
}
//store/actions.js
export default {
FETCH_NEWS(context) {
fetchNewsList()
.then(res => {
context.commit('SET_NEWS', res.data);
console.log('actions');
console.log(res);
return res;
})
.catch(err => {
console.error(err);
});
},
}
//api/index.js
function fetchNewsList() {
console.log('api call');
return axios.get(`${config.baseUrl}news/1.json`);
}
답변 4
2
2020. 01. 29. 19:40
안녕하세요 pius712님, 해당 내용에 대해 이후 강좌에서 설명하고 정정했습니다. 일단 제가 잘못 설명 드린 부분에 대해서 공식 문서까지 확인해가며 정확하게 파악하려고 하신 모습이 넘 보기 좋네요..! :) 말씀하신 것처럼 actions 함수에서 프로미스 리턴하면 됩니다. 아래 강좌를 참고해보세요 :)
1
0
0