> 웹 프론트엔드 > 프런트엔드 Q&A > Vue는 상위 창이 닫힐 때 작업을 수행하기 위해 하위 노드를 어떻게 구현합니까?

Vue는 상위 창이 닫힐 때 작업을 수행하기 위해 하위 노드를 어떻게 구현합니까?

PHPz
풀어 주다: 2023-04-12 10:08:10
원래의
1013명이 탐색했습니다.

Vue 하위 노드의 상위 창이 닫힙니다

Vue 애플리케이션에서는 상위 창이 닫힐 때 구성 요소(하위 노드)가 일부 작업을 수행해야 하는 상황에 자주 직면합니다.

예를 들어 모달 상자에서 모달 상자의 닫기 버튼을 클릭하면 양식이 제출되고 동시에 모달 상자 구성 요소가 소멸되기를 바랍니다.

Vue 애플리케이션에서 상위 창이 닫힐 때 일부 작업을 수행하기 위해 하위 노드를 어떻게 구현합니까?

방법 1: $emit 이벤트 사용

Vue 구성 요소는 사용자 정의 이벤트를 트리거하고 상위 구성 요소에 데이터를 전달하는 데 사용할 수 있는 $emit 메서드를 제공합니다.

하위 노드에서 상위 창의 닫기 이벤트를 수신한 다음 사용자 정의 이벤트를 트리거할 수 있습니다.

methods: {
  onClose() {
    this.$emit('close');
  }
}
로그인 후 복사

상위 창에서 하위 노드 레이블에 수신 이벤트를 바인딩하고 이벤트가 발생할 때 제출할 수 있습니다. 닫혀 있고 모달 상자 구성 요소를 파괴합니다.

<modal-dialog @close="handleSubmit">
  <!-- 模态框内容 -->
</modal-dialog>
로그인 후 복사
methods: {
  handleSubmit() {
    // 提交表单
    // ...

    // 销毁模态框组件
    this.$refs.modalDialog.$destroy();
  }
}
로그인 후 복사

방법 2: $parent 속성 사용

$emit 이벤트를 사용하는 것 외에도 $parent 속성을 사용하여 상위 구성 요소 인스턴스를 가져온 다음 호출할 수도 있습니다. 상위 구성 요소의 메서드.

하위 노드에서 $parent 속성을 사용하여 상위 구성 요소 인스턴스를 가져온 다음 상위 구성 요소의 닫기 메서드를 호출할 수 있습니다.

methods: {
  onClose() {
    this.$parent.close();
  }
}
로그인 후 복사

상위 창에서 모달 인스턴스에 닫기를 정의해야 합니다. box 구성 요소 메서드를 사용한 다음 하위 노드에서 메서드를 호출합니다.

<modal-dialog ref="modalDialog">
  <!-- 模态框内容 -->
</modal-dialog>
로그인 후 복사
mounted() {
  this.$refs.modalDialog.close = () => {
    // 提交表单
    // ...

    // 关闭模态框
    this.$refs.modalDialog.hide();
  }
}
로그인 후 복사

Summary

Vue 애플리케이션에서 상위 창이 닫힐 때 하위 노드가 일부 작업을 수행해야 하는 경우 $emit 이벤트 또는 $부모 속성.

$emit 이벤트를 사용하면 하위 노드 구성 요소가 더 유연해지고 다른 상위 구성 요소에서 재사용될 수 있지만 상위 구성 요소에서 수신 이벤트를 수동으로 작성해야 합니다.

$parent 속성을 사용하면 자식 노드 컴포넌트를 더욱 간결하게 만들 수 있습니다. 부모 컴포넌트의 메서드만 호출하면 되지만, 부모 컴포넌트에서 닫는 메서드를 수동으로 정의하고 자식 노드에 전달해야 합니다.

위 내용은 Vue는 상위 창이 닫힐 때 작업을 수행하기 위해 하위 노드를 어떻게 구현합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿