>웹 프론트엔드 >View.js >Vue 문서의 가치 전달 기능 단계에 대한 자세한 설명

Vue 문서의 가치 전달 기능 단계에 대한 자세한 설명

WBOY
WBOY원래의
2023-06-20 22:48:092063검색

Vue.js는 널리 사용되는 JavaScript 프레임워크로, 가장 큰 장점 중 하나는 강력한 데이터 바인딩 기능입니다. Vue.js에서는 데이터가 구성 요소를 통해 전달되며, 서로 다른 구성 요소 간에 데이터를 전달하기 위해 Vue.js는 $emit 및 $on과 같은 값 전달 함수를 제공합니다. 이 기사에서는 이러한 기능을 사용하여 가치 전송을 구현하는 방법을 자세히 설명합니다.

  1. 컴포넌트 통신의 기본 개념을 이해하세요

Vue.js로 개발할 때 일반적으로 여러 컴포넌트를 사용하여 함께 작업하여 완전한 애플리케이션을 구축해야 합니다. 따라서 구성 요소 간의 통신은 매우 중요하며 다양한 기능과 상호 작용을 구현하는 데 도움이 될 수 있습니다. Vue.js에는 컴포넌트 간 통신 방법이 두 가지 있습니다.

  • 부모 컴포넌트와 자식 컴포넌트 간 통신
  • 형제 컴포넌트 간 통신

부모 컴포넌트와 자식 컴포넌트 간 통신 시 props와 $emit 함수를 사용할 수 있습니다. 형제 구성 요소 간 통신 시 공통 상위 구성 요소의 도움을 받아 통신할 수 있습니다.

  1. $emit를 사용하여 상위 및 하위 구성 요소 간 통신 구현

$emit()은 Vue.js에서 매우 중요한 값 전달 함수로 상위 및 하위 구성 요소 간의 통신에 사용됩니다. 이 함수의 기능은 하위 구성요소에서 상위 구성요소로 사용자 정의 이벤트를 전달하는 것이며 일부 매개변수를 전달할 수 있습니다.

다음은 $emit()를 사용하여 상위 구성 요소와 하위 구성 요소 간의 통신을 구현하는 단계입니다.

1단계: 하위 구성 요소를 정의하고 $emit() 함수를 사용하여 구성 요소에서 이벤트를 트리거합니다.

<template>
  <div>
    <button @click="passData">传递数据</button>
  </div>
</template>
<script>
export default {
  methods: {
    passData() {
      this.$emit('get-data', 'Hello Vue')
    }
  }
}
</script>

위 코드에서는 하위 구성 요소를 정의하고 그 안에 버튼을 정의합니다. 버튼을 클릭하면 $emit() 함수를 사용하여 get-data라는 이벤트를 트리거하는 passData 메서드가 트리거됩니다. 문자열 매개변수 Hello Vue를 전달합니다.

2단계: 상위 구성 요소에서 v-on 지시어를 사용하여 하위 구성 요소에 의해 트리거된 이벤트를 수신하고 하위 구성 요소에서 전달된 매개 변수를 수신하는 핸들러 함수를 정의합니다.

<template>
  <div>
    <child-component @get-data="getData"></child-component>
    <p>接收到子组件传递的数据:{{ data }}</p>
  </div>
</template>
<script>
import ChildComponent from './ChildComponent'
export default {
  components: { ChildComponent },
  data() {
    return {
      data: ''
    }
  },
  methods: {
    getData(data) {
      this.data = data
    }
  }
}
</script>

위 코드에서는 v-on 명령을 사용하여 get-data라는 이벤트를 수신합니다. 하위 구성 요소가 이벤트를 트리거하면 getData라는 메서드가 호출되고 하위 구성 요소가 전달한 매개 변수가 전달됩니다. 방법을 알려주세요. 이 방법에서는 data 속성에 매개변수를 할당하여 상위 구성요소의 하위 구성요소가 전달한 데이터를 표시합니다.

  1. $on을 사용하여 형제 구성 요소 간의 통신 구현

$on()은 형제 구성 요소 간의 통신에 사용되는 Vue.js의 또 다른 중요한 값 전달 함수입니다. 이 함수의 기능은 하위 구성 요소에서 사용자 정의 이벤트를 수신하고 이벤트에 응답하는 것입니다.

다음은 $on()을 사용하여 형제 구성 요소 간의 통신을 구현하는 단계입니다.

1단계: 공통 상위 구성 요소를 정의합니다.

<template>
  <div>
    <child-component></child-component>
    <another-child-component></another-child-component>
  </div>
</template>

위 코드에서는 두 개의 하위 구성 요소를 포함하는 상위 구성 요소를 정의합니다.

2단계: 하위 구성 요소의 $on() 함수를 사용하여 맞춤 이벤트를 수신합니다.

<script>
export default {
  created() {
    this.$root.$on('trigger-event', this.handleEvent)
  },
  methods: {
    handleEvent() {
      console.log('Hello Vue!')
    }
  },
  destroyed() {
    this.$root.$off('trigger-event', this.handleEvent)
  }
}
</script>

위 코드에서는 생성된 후크 함수를 사용하여 하위 구성 요소가 생성될 때 Trigger-event라는 이벤트 수신을 시작합니다. 이벤트가 수신되면 이벤트를 처리하는 데 사용되는 handlerEvent라는 메서드가 호출됩니다. 또한 메모리 누수를 방지하기 위해 하위 구성 요소가 파괴될 때 이벤트 리스너를 제거하기 위해 파괴된 후크 기능을 사용합니다.

3단계: 다른 하위 구성 요소에서 $emit() 함수를 사용하여 이벤트를 트리거합니다.

<script>
export default {
  methods: {
    triggerEvent() {
      this.$root.$emit('trigger-event')
    }
  }
}
</script>

위 코드에서는 하위 구성 요소를 정의하고 그 안에 버튼을 정의했습니다. 사용자가 버튼을 클릭하면 $emit() 함수를 사용하여 Trigger-event라는 이벤트를 트리거하는 TriggerEvent 메서드가 호출됩니다.

  1. 요약

Vue.js에서는 $emit 및 $on 함수를 사용하여 상위-하위 구성 요소와 형제 구성 요소 간의 값 전송이 가능합니다. 먼저 하위 구성요소를 정의하고 그 안에 있는 $emit 함수를 사용하여 사용자 정의 이벤트를 트리거해야 합니다. 다음으로, 이벤트를 수신하고 핸들러 함수에서 하위 구성 요소가 전달한 매개변수를 처리하기 위해 상위 구성 요소의 v-on 지시문을 사용해야 합니다. 형제 구성 요소 간의 통신을 위해서는 $on 함수를 사용하여 공통 상위 구성 요소에서 사용자 정의 이벤트를 수신하고 $emit 함수를 사용하여 다른 하위 구성 요소에서 이벤트를 트리거해야 합니다. 이러한 값 전송 기능은 Vue.js의 매우 중요한 부분입니다. 이를 마스터하면 구성 요소 간에 데이터를 더 잘 전송할 수 있습니다.

위 내용은 Vue 문서의 가치 전달 기능 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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