상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - Vue.js에서 비동기 데이터 페칭을 위한 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
<a href='https://sangseek.com/sangseeks/Vue.js/ko'>Vue.js</a>에서 비동기 데이터 페칭은 웹 <a href='https://sangseek.com/sangseeks/애플/ko'>애플</a>리케이션에서 외부 API나 서버로부터 데이터를 가져오는 중요한 과정입니다. Vue.js는 비동기 작업을 처리하기 위한 여러 가지 방법을 제공합니다. 여기서는 Vue.js에서 비동기 데이터 페칭을 위한 다양한 방법과 그 사용 예를 자세히 설명하겠습니다. 1. Axios 사용하기 Axios는 Promise 기반의 HTTP 클라이언트로, Vue.js와 함께 자주 사용됩니다. Axios를 사용하면 API 요청을 쉽게 만들고 응답을 처리할 수 있습니다. 설치 ```bash npm install axios ``` 사용 예 ```javascript <template> <div> <h1>사용자 목록</h1> <ul> <li v-for="user in users" :key="user.id">{{ user.name }}</li> </ul> </div> </template> <script> import axios from 'axios'; export default { data() { return { users: [] }; }, mounted() { this.fetchUsers(); }, methods: { async fetchUsers() { try { const response = await axios.get('https://jsonplaceholder.typicode.com/users'); this.users = response.data; } catch (error) { console.error('데이터를 가져오는 중 오류 발생:', error); } } } }; </script> ``` 2. Fetch API 사용하기 Fetch API는 브라우저에서 제공하는 내장 API로, 비동기 HTTP 요청을 처리할 수 있습니다. Axios와 유사하지만, Fetch는 Promise를 <a href='https://sangseek.com/sangseeks/반환/ko'>반환</a>하며, 추가적인 설정이 필요할 수 있습니다. 사용 예 ```javascript <template> <div> <h1>사용자 목록</h1> <ul> <li v-for="user in users" :key="user.id">{{ user.name }}</li> </ul> </div> </template> <script> export default { data() { return { users: [] }; }, mounted() { this.fetchUsers(); }, methods: { async fetchUsers() { try { const response = await fetch('https://jsonplaceholder.typicode.com/users'); if (!response.ok) { throw new Error('네트워크 응답이 좋지 않습니다.'); } const data = await response.json(); this.users = data; } catch (error) { console.error('데이터를 가져오는 중 오류 발생:', error); } } } }; </script> ``` 3. Vuex를 통한 상태 관리 Vuex는 Vue.js 애플리케이션의 상태 관리를 위한 공식 라이브러리입니다. 비동기 데이터 페칭을 Vuex와 함께 사용하면 중앙 집중식으로 상태를 관리할 수 있습니다. 설치 ```bash npm install vuex ``` 사용 예 ```javascript // store.js import Vue from 'vue'; import Vuex from 'vuex'; import axios from 'axios'; Vue.use(Vuex); export default new Vuex.Store({ state: { users: [] }, mutations: { setUsers(state, users) { state.users = users; } }, actions: { async fetchUsers({ commit }) { try { const response = await axios.get('https://jsonplaceholder.typicode.com/users'); commit('setUsers', response.data); } catch (error) { console.error('데이터를 가져오는 중 오류 발생:', error); } } } }); ``` ```javascript // <a href='https://sangseek.com/sangseeks/App.vue/ko'>App.vue</a> <template> <div> <h1>사용자 목록</h1> <ul> <li v-for="user in users" :key="user.id">{{ user.name }}</li> </ul> </div> </template> <script> import { mapState } from 'vuex'; export default { computed: { ...mapState(['users']) }, mounted() { this.$store.dispatch('fetchUsers'); } }; </script> ``` 4. Composition API 사용하기 Vue 3에서는 Composition API를 도입하여 비동기 데이터 페칭을 더 유연하게 처리할 수 있습니다. `ref`와 `onMounted`를 사용하여 데이터를 가져오는 방법을 보여줍니다. 사용 예 ```javascript <template> <div> <h1>사용자 목록</h1> <ul> <li v-for="user in users" :key="user.id">{{ user.name }}</li> </ul> </div> </template> <script> import { ref, onMounted } from 'vue'; import axios from 'axios'; export default { setup() { const users = ref([]); const fetchUsers = async () => { try { const response = await axios.get('https://jsonplaceholder.typicode.com/users'); users.value = response.data; } catch (error) { console.error('데이터를 가져오는 중 오류 발생:', error); } }; onMounted(fetchUsers); return { users }; } }; </script> ``` 결론 Vue.js에서 비동기 데이터 페칭은 다양한 방법으로 구현할 수 있으며, 각 방법은 특정 상황에 따라 장단점이 있습니다. Axios는 간편한 API 요청을 제공하고, Fetch API는 브라우저 내장 기능으로 추가 라이브러리 없이 사용할 수 있습니다. Vuex는 상태 관리를 중앙 집중화하여 여러 컴포넌트에서 데이터를 공유할 수 있게 해줍니다. 마지막으로, Composition API는 더 유연하고 재사용 가능한 코드를 작성할 수 있도록 도와줍니다. 각 방법을 적절히 활용하여 효율적인 데이터 페칭을 구현할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기