웹 프론트엔드 View.js Vue의 구성 요소 전체에 메서드와 이벤트를 전달하기 위해 제공 및 주입을 사용하는 팁

Vue의 구성 요소 전체에 메서드와 이벤트를 전달하기 위해 제공 및 주입을 사용하는 팁

Jun 25, 2023 am 11:02 AM
vue provide inject

Vue는 뛰어난 오픈 소스 프런트 엔드 프레임워크로 사용자 인터페이스를 빠르게 구축하고 개발 프로세스를 단순화하며 제품 개발 효율성을 향상시키는 기능을 갖추고 있습니다. Vue는 소품, 방출, $emit, vuex 등을 포함하여 데이터를 전달하는 다양한 방법을 제공합니다. 구성 요소 수준에서 제공 및 주입을 사용하면 구성 요소 간에 메서드와 이벤트를 전달하는 데 도움이 될 수 있는 보다 유연한 방법입니다. 이 기사에서는 Vue에서 제공 및 주입을 사용하여 구성 요소 전체에 메서드와 이벤트를 전달하는 기술에 중점을 둘 것입니다.

  1. 제공과 주입이 무엇인가요?

provide 및 inject는 Vue의 고급 구성 요소 전달 방법으로, 상위 구성 요소가 자신에게서 멀리 떨어져 있는 하위 구성 요소에 데이터를 전달할 수 있도록 합니다. 상위 구성 요소에 데이터를 제공하여 모든 하위 구성 요소에서 데이터에 액세스할 수 있도록 할 수 있습니다.

  1. 제공과 주입을 어떻게 사용하나요?

먼저 동일한 메서드를 여러 구성 요소에 바인딩하는 예를 사용하여 제공 및 주입 사용 방법을 설명하겠습니다.

2.1 조상 컴포넌트는 메서드를 제공합니다

조상 컴포넌트에서는 메서드를 정의하고 이를 모든 하위 컴포넌트에 제공합니다. 코드는 다음과 같습니다.

import { provide } from 'vue'

export default {
  created() {
    const commonMethod = () => { alert('hello world') }
    provide('commonMethod', commonMethod)
  }
}
로그인 후 복사

여기에서는 제공 메소드를 사용하여 모든 하위 컴포넌트에 commonMethod 메소드를 제공합니다. 제공 메소드의 첫 번째 매개변수는 제공되는 데이터의 키 이름이고, 두 번째 매개변수는 제공되는 데이터의 특정 내용입니다.

2.2 하위 컴포넌트 수신 메소드

제공된 메소드를 받은 후 모든 하위 컴포넌트에서 사용할 수 있습니다. 코드는 다음과 같습니다.

import { inject } from 'vue'

export default {
  created() {
    const commonMethod = inject('commonMethod')
    this.$commonMethod = commonMethod
  }
}
로그인 후 복사

여기서는 inject 메소드를 사용하여 commonMethod 메소드를 전달받습니다. 주입 메소드의 매개변수는 제공된 데이터의 키 이름이며, 제공된 데이터의 값을 반환합니다. 생성된 라이프사이클에서는 구성 요소에서 사용할 인스턴스의 $commonMethod 변수에 commonMethod 메서드를 바인딩합니다.

  1. 전달 이벤트를 구현하는 방법은 무엇입니까?

구성요소 전반에 걸쳐 이벤트를 전달할 때 Provide와 Inject를 사용해야 합니다. 아래에서는 하위 구성 요소를 트리거하기 위해 버튼을 클릭하는 이벤트를 예로 들어 보겠습니다.

3.1 Ancestor 컴포넌트는 이벤트를 제공합니다.

Ancestor 컴포넌트에서는 이벤트 클래스를 도입하여 모든 하위 컴포넌트에 제공합니다. 코드는 다음과 같습니다.

import { provide } from 'vue'
import { EventEmitter } from 'events'

export default {
  created() {
    const emitter = new EventEmitter()
    provide('emitter', emitter)
  }
}
로그인 후 복사

여기서는 조상 컴포넌트에 새로운 EventEmitter 인스턴스를 생성하여 자손 컴포넌트에 제공합니다.

3.2 하위 컴포넌트는 이벤트를 수신합니다

하위 컴포넌트에서는 inject 메소드를 사용하여 제공된 이벤트를 가져오고 이벤트가 트리거된 후 해당 로직이 실행될 수 있도록 수신합니다. 코드는 다음과 같습니다.

import { inject } from 'vue'

export default {
  created() {
    const emitter = inject('emitter')
    emitter.on('event', () => {
      console.log('emit event')
    })
  }
}
로그인 후 복사

여기에서는 inject 메소드를 사용하여 제공된 이벤트 이미터를 수신하고 생성된 라이프사이클에서 'event' 이벤트를 수신합니다. 이벤트가 트리거되면 해당 로직을 실행합니다.

3.3 이벤트 트리거

이벤트를 트리거할 때 이미터를 가져와서 트리거해야 합니다. 코드는 다음과 같습니다.

import { inject } from 'vue'

export default {
  methods: {
    emitEvent() {
      const emitter = inject('emitter')
      emitter.emit('event')
    }
  }
}
로그인 후 복사

여기에서는 inject 메소드를 사용하여 제공된 이벤트 이미터를 가져오고, EmitEvent 메소드에서 'event' 이벤트를 트리거했습니다.

  1. 요약

이 글의 소개를 통해 우리는 메소드와 이벤트의 컴포넌트 간 전달을 구현하기 위해 Provide와 Inject를 사용하는 방법을 배웠습니다. Vue의 구성 요소 수준에서 제공 및 주입을 사용하면 데이터와 이벤트를 보다 유연하게 전달할 수 있어 템플릿이나 소품의 복잡성을 효과적으로 줄일 수 있습니다. 동시에 제공 및 주입은 DI(종속성 주입)와 유사한 기능을 제공하여 Vue의 아키텍처 설계를 더욱 확장 가능하고 유지 관리하기 쉽게 만듭니다.

위 내용은 Vue의 구성 요소 전체에 메서드와 이벤트를 전달하기 위해 제공 및 주입을 사용하는 팁의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

VUE를 사용하여 단일 헤더 및 다중 바디로 전자 따옴표 양식을 구현하는 방법은 무엇입니까? VUE를 사용하여 단일 헤더 및 다중 바디로 전자 따옴표 양식을 구현하는 방법은 무엇입니까? Apr 04, 2025 pm 11:39 PM

VUE의 단일 헤더 및 다중 바디로 전자 견적 양식을 구현하는 방법. 현대 기업 관리에서 인용 양식의 전자 처리는 효율성을 향상시키는 것입니다.

Vue-Router 점프 후 콘솔 네트워크에 페이지 요청 정보가없는 이유는 무엇입니까? Vue-Router 점프 후 콘솔 네트워크에 페이지 요청 정보가없는 이유는 무엇입니까? Apr 04, 2025 pm 05:27 PM

Vue-Router 점프 후 콘솔 네트워크에 페이지 요청 정보가없는 이유는 무엇입니까? 페이지 리디렉션에 Vue-Router를 사용하는 경우

프론트 엔드에서 다른 브랜드의 고성능 작가의 사진 업로드 기능을 구현하는 방법은 무엇입니까? 프론트 엔드에서 다른 브랜드의 고성능 작가의 사진 업로드 기능을 구현하는 방법은 무엇입니까? Apr 04, 2025 pm 05:42 PM

프론트 엔드에서 다양한 브랜드의 고음문 작가의 사진 업로드 기능을 구현하는 방법 프론트 엔드 프로젝트를 개발할 때 종종 하드웨어 장비를 통합 해야하는 경우가 종종 있습니다. 을 위한...

45도 곡선 테두리로 분할 효과를 달성하는 방법? 45도 곡선 테두리로 분할 효과를 달성하는 방법? Apr 04, 2025 pm 11:48 PM

사용자 인터페이스 디자인에서 세그먼트 효과를 구현하기위한 팁, 세그먼터는 특히 모바일 애플리케이션 및 반응 형 웹 페이지에서 일반적인 탐색 요소입니다. ...

맵 박스를 사용하여 맵에서 3D 객체의 하단이 고정되어 있는지, vue에서 3.js를 사용하는 방법은 무엇입니까? 맵 박스를 사용하여 맵에서 3D 객체의 하단이 고정되어 있는지, vue에서 3.js를 사용하는 방법은 무엇입니까? Apr 04, 2025 pm 06:42 PM

VUE에서 Mapbox 및 Three.JS를 사용하여 3 차원 객체를 조정하여보기 각도를 매핑하는 방법. Vue를 사용하여 Mapbox와 Three.js를 결합 할 때 생성 된 3 차원 객체는 ...

JavaScript 이름 지정 사양은 Android WebView에서 호환성 문제를 제기합니까? JavaScript 이름 지정 사양은 Android WebView에서 호환성 문제를 제기합니까? Apr 04, 2025 pm 07:15 PM

JavaScript 이름 지정 사양 및 Android ...

el-table을 사용하여 vue2에서 테이블 그룹화, 드래그 앤 드롭 정렬을 구현하는 방법은 무엇입니까? el-table을 사용하여 vue2에서 테이블 그룹화, 드래그 앤 드롭 정렬을 구현하는 방법은 무엇입니까? Apr 04, 2025 pm 07:54 PM

vue2에서 el-table 테이블 그룹 드래그 앤 드롭 정렬 구현. EL-TABLE 테이블을 사용하여 VUE2에서 그룹 드래그 앤 드롭 정렬을 구현하는 것이 일반적인 요구 사항입니다. 우리가 ...

See all articles