inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Vue.js 중급 강좌 - 웹앱 제작으로 배워보는 Vue.js, ES6, Vuex

Vuex 설치 및 등록

vuex + axios 질문 있습니다!

198

박용석

작성한 질문수 2

1

안녕하세요, 강의 다 듣고 혼자서 이것저것 보면서 만들다가 궁금증이 생겨서 문의 드려봅니다.

 

vuex 에서 helper 기능을 사용 및 axios 통해서 데이터를 받아서 리스트를 뿌려보는 예제를 혼자 만들어 보았는데,

원래 axios 기능을 사용하면 then,catch, 등으로 resp 및 에러체크를 하는데

vuex actions 에서 동작시킬 때 async/await를 사용해서 코드작성할 때

이렇게 작성해도 문제가 없을까요??

mutations : {
        setUsers(state, data){
            state.users.push(data);
        }
    },
    actions : {
        async getUsers({commit}){
            let resp = '';
            try{
                resp = await axios.get('https://jsonplaceholder.typicode.com/todos');
                for(var i=0; i<resp.data.length; i++){
                    const data = resp.data[i];
                    this.state.users.push(data);
                }
            }catch(e){
                console.log(e);
            }
            commit("setUsers", resp.data);
        }
    }

javascript vue.js es6 vuex

답변 2

0

캡틴판교

안녕하세요 용석님, 네 괜찮을 것 같아요 :)

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 박용석님.

vuex에서 axios와 비동기 통신을 사용하면서 async/await를 사용하는 것에 대해 질문해주셨군요. 이에 대해 도움이 될 만한 관련 질문과 답변 링크를 몇 가지 제공해 드리겠습니다.

  1. actions / mutations 에 대하여

    • 이 질문에서는 actions와 mutations의 역할과 사용 방식에 대해 설명하고 있습니다. 주로 비동기 처리 로직은 actions에서 수행하고, 상태 변경은 mutations에서 처리하는 것을 권장하는 이유를 다루고 있습니다.
  2. 비동기 컴포넌트 체이닝

    • 비슷한 비동기 처리 예제와 관련된 질문으로, 비동기 처리가 올바르게 동작하지 않는 경우에 대하여 다루고 있습니다. 이 답변에서는 비동기 처리를 위해 적절히 에러를 다루는 방법에 대해서도 설명하고 있습니다.

질문해 주신 코드 예제에서 commit을 사용하는 부분에서 약간의 수정이 필요할 수 있습니다. this.state 대신에 context 객체를 사용하여 접근하는 것이 좋습니다. 또한, state를 직접 수정하는 대신 mutations를 통해 상태를 업데이트하는 것이 Vuex의 권장 방식입니다.

다음은 개선된 예제 코드입니다:

mutations: {
    setUsers(state, data) {
        state.users = data; // 직접 배열을 설정하는 형태로 수정
    }
},
actions: {
    async getUsers({ commit }) {
        try {
            const response = await axios.get('https://jsonplaceholder.typicode.com/todos');
            commit("setUsers", response.data);
        } catch (e) {
            console.log(e);
        }
    }
}

위 코드에서는 commit을 사용하여 state를 업데이트하고, response의 데이터를 setUsers mutation을 통해 설정합니다. 이렇게 하면 더 일관되고 명확한 상태 관리가 가능합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

Chrome 개발자 모드 확장이 안됨

0

253

1

깃 권한 요청드립니다

0

118

1

vue.js 중급 리포지토리 권한 관련

0

118

1

깃 권한 요청드립니다!

0

161

1

강의 깃주소 문의

0

142

1

router-view에 props를 어떻게 넘길 수 있나요?

1

278

2

Vue가 인식되지 않는 현상

0

205

1

기초강좌는 어디있나요?

1

190

2

App.vue가 필요한 이유

0

192

1

getter가 정의되어 있지 않아 오류가 발생합니다.

1

253

1

뷰 라이프사이클

1

187

1

TSLint 말고 TSLint Vue 설치해도 되나요?

1

367

3

로컬 스토리지는 어디에 있나요?

1

279

1

vuex 실행시 새로고침해야지만 리스트에 나타나는 현상

1

387

2

export default 관련한 질문

0

354

2

깃허브 vue-todo 접근불가에 따른 확인요청

1

354

2

깃허브에 문제있는것 같습니다.

1

273

2

인프런 강의 재생 화면 구성 변경 문의드립니다

1

303

2

addTodo Helper 함수 적용

1

242

1

vuex 헬퍼 전역 설정

1

244

2

github 권한요청드립니다.

1

255

2

이벤트 위치에 대한 궁금증 입니다.

1

221

2

구조 차이에 대한 문의

1

343

2

TodoList.vue에서 삭제 처리를 위한 emit이 작동하지 않습니다.

1

565

2