상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
궁금한 상식 보기
클라우드 컴퓨팅의 비동기 처리(Asynchronous Processing) 방법은 무엇인가요?
클라우드 컴퓨팅에서 에지 컴퓨팅의 적용 사례는 무엇인가요?
체리토마토를 활용한 간편식은 어떤 것이 있을까요?
체리토마토를 갈아서 만드는 음료는 어떤 것이 있나요?
전기 재충전소의 중요성은 무엇인가요?
전기 네트워크의 구조와 기능은 무엇인가요?
신용카드의 프리미엄 서비스는 어떤 것들이 있나요?
신용카드의 에러가 발생했을 때 어떻게 해결하나요?
근로장려금의 혜택을 최대한 활용하려면 어떻게 해야 하나요?
근로장려금에 대한 정책 변화는 어떻게 확인하나요?
라벤더의 일반적인 식물학적 특성은 무엇인가요?
라벤더를 기르는 데 도움이 되는 커뮤니티는 무엇이 있나요?
Previous
Next
수정하기 - Vue.js에서 커스텀 이벤트를 사용하는 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
Vue.js에서 커스텀 이벤트는 컴포넌트 간의 통신을 위한 강력한 도구입니다. 특히 부모와 자식 컴포넌트 간의 데이터 흐름을 관리하는 데 유용합니다. 커스텀 이벤트를 사용하면 자식 컴포넌트가 부모 컴포넌트에 특정 이벤트를 알릴 수 있으며, 이를 통해 부모 컴포넌트가 적절한 반응을 할 수 있습니다. 아래에서는 Vue.js에서 커스텀 이벤트를 사용하는 방법에 대해 자세히 설명하겠습니다. 1. 커스텀 이벤트의 기본 개념 Vue.js에서 커스텀 이벤트는 `this.$emit` 메서드를 사용하여 발생시킬 수 있습니다. 자식 컴포넌트에서 이벤트를 발생시키면, 부모 컴포넌트는 해당 이벤트를 수신하고 처리할 수 있습니다. 이 방식은 Vue의 단방향 데이터 흐름을 유지하면서도 컴포넌트 간의 상호작용을 가능하게 합니다. 2. 커스텀 이벤트 생성하기 자식 컴포넌트에서 커스텀 이벤트를 생성하려면, `this.$emit` 메서드를 사용합니다. 이 메서드는 두 개의 인자를 받을 수 있습니다: 이벤트 이름과 전달할 데이터입니다. ```javascript // ChildComponent.vue <template> <button @click="notifyParent">Click me</button> </template> <script> export default { methods: { notifyParent() { this.$emit('custom-event', 'Hello from Child!'); } } } </script> ``` 위의 예제에서 `notifyParent` 메서드는 버튼 클릭 시 `custom-event`라는 이름의 커스텀 이벤트를 발생시키고, 문자열 `'Hello from Child!'`를 부모에게 전달합니다. 3. 부모 컴포넌트에서 이벤트 수신하기 부모 컴포넌트는 자식 컴포넌트를 사용할 때, `v-on` 디렉티브 또는 `@` 단축 구문을 사용하여 커스텀 이벤트를 수신할 수 있습니다. ```javascript // <a href='https://sangseek.com/sangseeks/ParentComponent/ko'>ParentComponent</a>.vue <template> <div> <ChildComponent @custom-event="handleCustomEvent" /> </div> </template> <script> import ChildComponent from './ChildComponent.vue'; export default { components: { ChildComponent }, methods: { handleCustomEvent(message) { console.log(message); // "Hello from Child!" } } } </script> ``` 위의 예제에서 `ParentComponent`는 `ChildComponent`의 `custom-event`를 수신하고, `handleCustomEvent` 메서드를 호출합니다. 이 메서드는 자식 컴포넌트에서 전달된 메시지를 콘솔에 출력합니다. 4. 여러 개의 이벤트 처리하기 하나의 자식 컴포넌트에서 여러 개의 커스텀 이벤트를 발생시킬 수도 있습니다. 각 이벤트는 서로 다른 이름을 가질 수 있으며, 부모 컴포넌트에서 각각의 이벤트를 처리할 수 있습니다. ```javascript // ChildComponent.vue methods: { notifyParent() { this.$emit('custom-event', 'Hello from Child!'); this.$emit('another-event', 'Another message from Child!'); } } ``` ```javascript // ParentComponent.vue <template> <div> <ChildComponent @custom-event="handleCustomEvent" @another-event="handleAnotherEvent" /> </div> </template> methods: { handleCustomEvent(message) { console.log(message); }, handleAnotherEvent(message) { console.log(message); } } ``` 5. 이벤트 버스(Event Bus) 사용하기 Vue.js에서는 이벤트 버스를 사용하여 비슷한 방식으로 여러 컴포넌트 간의 통신을 할 수 있습니다. 이벤트 버스는 Vue 인스턴스를 사용하여 중앙 집중식으로 이벤트를 관리하는 방법입니다. 그러나 Vue 3에서는 Composition API와 provide/inject 패턴을 사용하는 것이 더 권장됩니다. 6. Vue 3의 Composition API에서의 커스텀 이벤트 Vue 3에서는 Composition API를 사용하여 커스텀 이벤트를 처리할 수 있습니다. `setup` 함수 내에서 `emit`을 사용하여 이벤트를 발생시킬 수 있습니다. ```javascript // ChildComponent.vue <template> <button @click="notifyParent">Click me</button> </template> <script> import { defineComponent, toRefs } from 'vue'; export default defineComponent({ setup(props, { emit }) { const notifyParent = () => { emit('custom-event', 'Hello from Child!'); }; return { notifyParent }; } }); </script> ``` 부모 컴포넌트에서의 사용법은 동일합니다. 결론 Vue.js에서 커스텀 이벤트는 컴포넌트 간의 통신을 간편하게 만들어주는 중요한 기능입니다. 자식 컴포넌트에서 이벤트를 발생시키고, 부모 컴포넌트에서 이를 수신하여 적절한 처리를 할 수 있습니다. 이러한 방식은 Vue의 단방향 데이터 흐름을 유지하면서도 유연한 컴포넌트 설계를 가능하게 합니다. 커스텀 이벤트를 적절히 활용하면, 복잡한 애플리케이션에서도 컴포넌트 간의 상호작용을 효과적으로 관리할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기