웹 프론트엔드 View.js Vue2.x(props, $emit, Vuex)에서 컴포넌트 통신 구현에 대한 전체 가이드

Vue2.x(props, $emit, Vuex)에서 컴포넌트 통신 구현에 대한 전체 가이드

Jun 09, 2023 pm 04:06 PM
vuex 컴포넌트 통신

Vue2.x(props, $emit, Vuex)에서 구성요소 통신 구현에 대한 전체 가이드

Vue는 최신 JavaScript 프레임워크로서 웹 애플리케이션을 개발할 때 매우 널리 사용됩니다. Vue의 구성요소화된 아키텍처를 통해 개발자는 코드와 기능을 쉽게 분리하는 동시에 다양한 구성요소를 통해 유연한 통신을 가능하게 합니다.

이 기사에서는 Vue 애플리케이션을 구축할 때 리소스를 더 잘 관리하는 데 도움이 되는 Vue2.x의 세 가지 구성 요소 통신 방법인 props, $emit 및 Vuex를 살펴보겠습니다.

Props

props는 Vue의 컴포넌트 매개변수 전달 방법 중 하나입니다. props를 사용하여 자식 컴포넌트에 값을 전달할 수 있습니다. 하위 컴포넌트에서 props의 값은 읽기 전용이므로 수정할 수 없습니다. 이를 통해 단방향 데이터 흐름이 가능해 Vue 애플리케이션을 더 쉽게 유지 관리하고 디버깅할 수 있습니다.

예는 다음과 같습니다.

상위 구성 요소에서 "parent"라는 prop을 만들고 "message"라는 prop을 전달할 수 있습니다.

<template>
  <div>
    <child :message="msg"></child>
  </div>
</template>

<script>
import Child from "./Child.vue";

export default {
  name: "Parent",
  components: {
    Child
  },
  data() {
    return {
      msg: "Hello World!"
    };
  }
};
</script>
로그인 후 복사

자식 구성 요소에서는 전달된 props 값을 받아 템플릿에서 사용할 수 있습니다.

<template>
  <div>
    {{ message }}
  </div>
</template>

<script>
export default {
  name: "Child",
  props: {
    message: {
      type: String,
      required: true
    }
  }
};
</script>
로그인 후 복사

이 예에서 "msg"는 상위 구성 요소에 정의되어 있고 "message"는 props의 이름입니다. 이는 상위 구성 요소의 값과 일치해야 합니다. 하위 컴포넌트는 "props" 옵션을 사용하여 전달되어야 하는 props의 데이터 유형과 값을 정의해야 합니다.

props를 통한 데이터 전달의 기본 예시입니다. 전달해야 하는 props가 여러 개인 경우 객체에 넣고 하위 구성 요소에 전달할 수 있습니다.

$emit

$emit은 Vue에서 널리 사용되는 또 다른 구성 요소 통신 방법입니다. $emit를 사용하여 사용자 정의 이벤트를 트리거하고 데이터를 상위 구성 요소에 전달할 수 있습니다. props와 달리 $emit는 양방향 데이터 전송이 가능하므로 Vue 애플리케이션의 구성 요소 간 리소스 공유가 더욱 편리해집니다.

props와 달리 $emit는 하위 구성 요소에서 상위 구성 요소로 데이터를 전달할 수 있습니다. 예는 다음과 같습니다.

이 예에서는 사용자 정의 이벤트 이름 "인사말"을 정의하고 버튼을 클릭할 때 이벤트를 트리거합니다. 또한 선택한 항목을 이벤트에 전달합니다.

<template>
  <div>
    <button @click="sayHi()">Click me</button>
  </div>
</template>

<script>
export default {
  name: "Child",
  methods: {
    sayHi() {
      this.$emit("greeting", {
        message: "Hello World!"
      });
    }
  }
};
</script>
로그인 후 복사

상위 구성 요소에서는 하위 구성 요소의 사용자 정의 이벤트를 수신하고 이벤트가 실행될 때 전달된 데이터를 사용할 수 있습니다.

<template>
  <div>
    <child @greeting="handleGreeting"></child>
    <div>{{ greeting }}</div>
  </div>
</template>

<script>
import Child from "./Child.vue";

export default {
  name: "Parent",
  components: {
    Child
  },
  data() {
    return {
      greeting: ""
    };
  },
  methods: {
    handleGreeting(data) {
      this.greeting = data.message;
    }
  }
};
</script>
로그인 후 복사

이 예에서 "handleGreeting"은 이벤트를 처리하는 데 사용되는 메서드입니다. 이 메소드는 하위 구성요소에 의해 트리거된 사용자 정의 이벤트를 매개변수로 수신합니다. 데이터 전송은 하위 구성 요소의 $emit 이벤트에서 얻을 수 있습니다.

Vuex

Vuex는 Vue.js 애플리케이션을 위한 상태 관리 라이브러리입니다. 이를 통해 구성 요소가 상태를 공유할 수 있으므로 구성 요소 간의 통신이 더욱 쉽고 효율적으로 이루어집니다.

예는 다음과 같습니다.

이 예에서는 "store"라는 Vuex 스토어를 생성하여 데이터를 공유합니다. 상태 속성에서 공유해야 하는 데이터를 정의할 수 있습니다. mutations 속성에서는 저장소의 데이터를 수정하는 함수를 정의할 수 있습니다. getter 속성에서는 데이터를 처리하고 공유 값을 반환하는 함수를 정의할 수 있습니다.

import Vue from "vue";
import Vuex from "vuex";

Vue.use(Vuex);

export default new Vuex.Store({
  state: {
    greeting: "Hello World!"
  },
  mutations: {
    changeGreeting(state, payload) {
      state.greeting = payload.greeting;
    }
  },
  getters: {
    getGreeting(state) {
      return state.greeting;
    }
  }
});
로그인 후 복사

모든 Vue 구성 요소에서 스토어의 데이터와 기능을 사용할 수 있습니다. 이 예에서는 두 개의 버튼이 설정되어 있습니다. "인사말" 버튼을 클릭하면 매장에 "인사말" 속성 값이 표시됩니다. "인사말 변경" 버튼은 commit 함수를 통해 mutations 속성에 정의한 함수를 호출하여 스토어의 "인사말" 값을 변경합니다.

<template>
  <div>
    <div>{{ greeting }}</div>
    <button @click="getGreeting">greeting</button>
    <button @click="changeGreeting">change greeting</button>
  </div>
</template>

<script>
import { mapGetters, mapMutations } from "vuex";

export default {
  name: "Child",
  computed: {
    ...mapGetters(["getGreeting"])
  },
  methods: {
    ...mapMutations(["changeGreeting"]),
    getGreeting() {
      alert(this.getGreeting);
    }
  }
};
</script>
로그인 후 복사

이 예에서는 "mapGetters" 및 "mapMutations"를 사용하여 저장소의 데이터와 함수를 구성 요소의 계산된 속성 및 메서드에 매핑할 수 있습니다. 이 메서드에서는 경고를 사용하여 매장의 "인사말" 속성 값을 표시합니다. "인사말 변경" 버튼을 클릭하면 상점의 "인사말" 속성을 변경하기 위해 ChangeGreeting 함수가 호출됩니다.

요약

위는 Vue2.x에서 컴포넌트 통신을 구현하는 세 가지 방법인 props, $emit 및 Vuex입니다. 실제 개발에서는 다양한 요구 사항과 시나리오에 따라 사용할 통신 방법을 선택할 수 있습니다.

props를 통해 단방향 데이터 전송을 달성하여 구성 요소 간 명확한 데이터 흐름을 보장할 수 있습니다. $emit는 구성 요소 간 양방향 데이터 전송을 수행하여 Vue 애플리케이션의 구성 요소 간 리소스 공유를 더욱 편리하게 만듭니다. 저장소에 저장할 수 있어 구성 요소 간 통신이 더 쉽고 효율적으로 이루어집니다.

위 내용은 Vue2.x(props, $emit, Vuex)에서 컴포넌트 통신 구현에 대한 전체 가이드의 상세 내용입니다. 자세한 내용은 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Vue 애플리케이션에서 vuex를 사용할 때 '오류: [vuex] 알 수 없는 작업 유형: xxx' 문제를 해결하는 방법은 무엇입니까? Vue 애플리케이션에서 vuex를 사용할 때 '오류: [vuex] 알 수 없는 작업 유형: xxx' 문제를 해결하는 방법은 무엇입니까? Jun 25, 2023 pm 12:09 PM

Vue.js 프로젝트에서 vuex는 매우 유용한 상태 관리 도구입니다. 이는 여러 구성 요소 간에 상태를 공유하는 데 도움이 되며 상태 변경을 관리하는 안정적인 방법을 제공합니다. 그러나 vuex를 사용할 때 가끔 "Error:[vuex]unknownactiontype:xxx" 오류가 발생합니다. 이 기사에서는 이 오류의 원인과 해결 방법을 설명합니다. 1. 오류 원인 vuex를 사용할 때 몇 가지 액션과 뮤를 정의해야 합니다.

Vue 애플리케이션에서 vuex를 사용할 때 '오류: [vuex]는 돌연변이 처리기 외부에서 vuex 저장소 상태를 변경하지 않습니다.' 문제를 해결하는 방법은 무엇입니까? Vue 애플리케이션에서 vuex를 사용할 때 '오류: [vuex]는 돌연변이 처리기 외부에서 vuex 저장소 상태를 변경하지 않습니다.' 문제를 해결하는 방법은 무엇입니까? Jun 24, 2023 pm 07:04 PM

Vue 애플리케이션에서는 vuex를 사용하는 것이 일반적인 상태 관리 방법입니다. 그러나 vuex를 사용할 때 "오류:[vuex]donotmutatevuexstorestateoutsidemutationhandlers"와 같은 오류 메시지가 나타날 수 있습니다. 이 오류 메시지는 무엇을 의미합니까? 이 오류 메시지가 나타나는 이유는 무엇입니까? 이 오류를 해결하는 방법은 무엇입니까? 이 기사에서는 이 문제를 자세히 다룰 것입니다. 오류 메시지에는 다음이 포함됩니다.

Vue 및 Vue-Router: 구성 요소 간에 데이터를 공유하는 방법은 무엇입니까? Vue 및 Vue-Router: 구성 요소 간에 데이터를 공유하는 방법은 무엇입니까? Dec 17, 2023 am 09:17 AM

Vue 및 Vue-Router: 구성 요소 간에 데이터를 공유하는 방법은 무엇입니까? 소개: Vue는 사용자 인터페이스 구축에 널리 사용되는 JavaScript 프레임워크입니다. Vue-Router는 단일 페이지 애플리케이션을 구현하는 데 사용되는 Vue의 공식 라우팅 관리자입니다. Vue 애플리케이션에서 컴포넌트는 사용자 인터페이스를 구축하기 위한 기본 단위입니다. 많은 경우 서로 다른 구성 요소 간에 데이터를 공유해야 합니다. 이 기사에서는 Vue 및 Vue-Router에서 데이터 공유를 달성하는 데 도움이 되는 몇 가지 방법을 소개합니다.

Vuex를 사용하여 Vue2.x에서 전역 상태를 관리하는 모범 사례 Vuex를 사용하여 Vue2.x에서 전역 상태를 관리하는 모범 사례 Jun 09, 2023 pm 04:07 PM

Vue2.x는 현재 가장 널리 사용되는 프런트 엔드 프레임워크 중 하나이며 전역 상태 관리를 위한 솔루션으로 Vuex를 제공합니다. Vuex를 사용하면 상태 관리가 더욱 명확해지고 유지 관리가 쉬워집니다. 개발자가 Vuex를 더 잘 사용하고 코드 품질을 향상하는 데 도움이 되도록 Vuex의 모범 사례가 아래에 소개됩니다. 1. 모듈식 조직 상태를 사용합니다. Vuex는 단일 상태 트리를 사용하여 애플리케이션의 모든 상태를 관리하고 구성 요소에서 상태를 추출하여 상태 관리를 더 명확하고 이해하기 쉽게 만듭니다. 상태가 많은 애플리케이션에서는 모듈을 사용해야 합니다.

Vue 컴포넌트 통신: 컴포넌트 통신을 위한 콜백 함수 사용 Vue 컴포넌트 통신: 컴포넌트 통신을 위한 콜백 함수 사용 Jul 09, 2023 pm 07:42 PM

Vue 컴포넌트 통신: 컴포넌트 통신을 위한 콜백 함수 사용 Vue 애플리케이션에서는 때때로 서로 다른 컴포넌트가 정보를 공유하고 협업할 수 있도록 서로 통신하도록 해야 합니다. Vue는 구성 요소 간의 통신을 구현하는 다양한 방법을 제공하며, 일반적인 방법 중 하나는 콜백 함수를 사용하는 것입니다. 콜백 함수는 함수가 다른 함수에 인수로 전달되고 특정 이벤트가 발생할 때 호출되는 메커니즘입니다. Vue에서는 콜백 함수를 사용하여 구성 요소 간의 통신을 구현할 수 있습니다.

vue3 구성 요소 간에 통신하는 방법은 무엇입니까? 의사소통 방법에 대한 간략한 분석 vue3 구성 요소 간에 통신하는 방법은 무엇입니까? 의사소통 방법에 대한 간략한 분석 Apr 21, 2023 pm 07:53 PM

vue3을 작성하는 프로젝트에서 우리는 모두 pinia 공개 데이터 소스를 사용하는 것 외에도 어떤 간단한 API 방법을 사용할 수 있습니까? 다음으로 부모-자식 구성 요소와 자식-부모 구성 요소 간에 통신하는 여러 가지 방법을 소개하겠습니다.

Vue3에서 Vuex를 사용하는 방법 Vue3에서 Vuex를 사용하는 방법 May 14, 2023 pm 08:28 PM

Vuex는 무엇을 하나요? Vue 공식: 상태 관리 도구 상태 관리란 무엇입니까? 상태는 여러 구성 요소 간에 공유되어야 하며 하나의 변경으로 모든 것이 변경됩니다. 예를 들어 사용자 로그인 상태, 사용자 이름, 지리적 위치 정보, 장바구니 항목 등 전역적으로 사용되는 일부 상태 정보가 있습니다. 이때 전역 상태 관리를 위한 도구가 필요하며 Vuex가 그러한 도구입니다. 단일 페이지 상태 관리 View–>Actions–>State 뷰 레이어(view)는 상태(state)를 변경하기 위한 액션(action)을 트리거하고 뷰 레이어(view) vuex(Vue3.0)에 다시 응답합니다.

vuex의 구현 원칙에 대해 자세히 알아보세요. vuex의 구현 원칙에 대해 자세히 알아보세요. Mar 20, 2023 pm 06:14 PM

인터뷰에서 vuex의 구현 원리에 대한 질문을 받았을 때 어떻게 답해야 할까요? 다음 기사는 vuex의 구현 원리에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다.

See all articles