상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - Vue.js에서 컴포넌트 간의 통신 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
Vue.js에서 컴포넌트 간의 통신은 애플리케이션의 구조와 데이터 흐름을 관리하는 데 중요한 요소입니다. Vue.js는 다양한 방법으로 컴포넌트 간의 통신을 지원하며, 각 방법은 특정 상황에 맞게 사용될 수 있습니다. 아래에서는 Vue.js에서 컴포넌트 간의 통신 방법에 대해 자세히 설명하겠습니다. 1. Props와 Events Props 부모 컴포넌트에서 자식 컴포넌트로 데이터를 전달할 때 `props`를 사용합니다. `props`는 자식 컴포넌트가 부모로부터 받은 데이터를 읽기 전용으로 사용할 수 있게 해줍니다. ```vue <!-- <a href='https://sangseek.com/sangseeks/ParentComponent/ko'>ParentComponent</a>.vue --> <template> <ChildComponent :message="parentMessage" /> </template> <script> export default { data() { return { parentMessage: 'Hello from Parent!' }; } }; </script> ``` ```vue <!-- ChildComponent.vue --> <template> <div>{{ message }}</div> </template> <script> export default { props: ['message'] }; </script> ``` Events 자식 컴포넌트에서 부모 컴포넌트로 이벤트를 전달할 때는 `$emit` 메서드를 사용합니다. 자식 컴포넌트에서 특정 이벤트가 발생했을 때 부모 컴포넌트에 알릴 수 있습니다. ```vue <!-- ChildComponent.vue --> <template> <button @click="sendMessage">Send Message</button> </template> <script> export default { methods: { sendMessage() { this.$emit('messageSent', 'Hello from Child!'); } } }; </script> ``` ```vue <!-- ParentComponent.vue --> <template> <ChildComponent @messageSent="handleMessage" /> </template> <script> export default { methods: { handleMessage(message) { console.log(message); } } }; </script> ``` 2. Vuex (상태 관리 패턴) Vuex는 Vue.js 애플리케이션의 상태 관리를 위한 공식 라이브러리입니다. 여러 컴포넌트 간에 상태를 공유하고 관리할 수 있는 중앙 집중식 저장소를 제공합니다. Vuex를 사용하면 컴포넌트 간의 통신이 더 간단하고 일관되게 이루어질 수 있습니다. ```javascript // store.js import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); export default new Vuex.Store({ state: { message: 'Hello from Vuex!' }, mutations: { updateMessage(state, newMessage) { state.message = newMessage; } }, actions: { setMessage({ commit }, newMessage) { commit('updateMessage', newMessage); } } }); ``` ```vue <!-- ComponentA.vue --> <template> <div>{{ message }}</div> </template> <script> import { mapState } from 'vuex'; export default { computed: { ...mapState(['message']) } }; </script> ``` ```vue <!-- ComponentB.vue --> <template> <button @click="changeMessage">Change Message</button> </template> <script> import { mapActions } from 'vuex'; export default { methods: { ...mapActions(['setMessage']), changeMessage() { this.setMessage('New message from ComponentB!'); } } }; </script> ``` 3. Provide / Inject `provide`와 `inject`는 상위 컴포넌트에서 하위 컴포넌트로 데이터를 전달하는 방법입니다. 이 방법은 깊은 컴포넌트 트리에서 데이터를 전달할 때 유용합니다. ```vue <!-- ParentComponent.vue --> <template> <ChildComponent /> </template> <script> export default { provide() { return { message: 'Hello from Parent!' }; } }; </script> ``` ```vue <!-- ChildComponent.vue --> <template> <GrandChildComponent /> </template> <script> import GrandChildComponent from './GrandChildComponent.vue'; export default { components: { GrandChildComponent } }; </script> ``` ```vue <!-- GrandChildComponent.vue --> <template> <div>{{ message }}</div> </template> <script> export default { inject: ['message'] }; </script> ``` 4. Event Bus 이벤트 버스는 Vue 인스턴스를 사용하여 컴포넌트 간에 이벤트를 전달하는 방법입니다. 그러나 Vue 3에서는 Composition API와 Vuex를 사용하는 것이 더 권장됩니다. ```javascript // eventBus.js import Vue from 'vue'; export const EventBus = new Vue(); ``` ```vue <!-- ComponentA.vue --> <template> <button @click="sendMessage">Send Message</button> </template> <script> import { EventBus } from './eventBus'; export default { methods: { sendMessage() { EventBus.$emit('messageSent', 'Hello from ComponentA!'); } } }; </script> ``` ```vue <!-- ComponentB.vue --> <template> <div>{{ message }}</div> </template> <script> import { EventBus } from './eventBus'; export default { data() { return { message: '' }; }, created() { EventBus.$on('messageSent', (msg) => { this.message = msg; }); }, beforeDest<a href='https://sangseek.com/sangseeks/roy/ko'>roy</a>() { EventBus.$off('messageSent'); } }; </script> ``` 결론 Vue.js에서 컴포넌트 간의 통신은 다양한 방법으로 이루어질 수 있으며, 각 방법은 특정 상황에 맞게 선택할 수 있습니다. `props`와 `events`는 기본적인 통신 방법이며, Vuex는 상태 관리가 필요한 경우에 유용합니다. `provide/inject`는 깊은 컴포넌트 트리에서 데이터를 전달할 때 유용하며, 이벤트 버스는 간단한 이벤트 전달에 사용할 수 있습니다. 애플리케이션의 구조와 요구 사항에 따라 적절한 방법을 선택하여 컴포넌트 간의 통신을 구현하는 것이 중요합니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기