Vue에서 값을 전달하는 세 가지 방법은 무엇입니까?

青灯夜游
풀어 주다: 2023-01-13 00:45:25
원래의
3679명이 탐색했습니다.

Vue에는 세 가지 값 전달 방법이 있습니다. 1. "아버지에서 자식으로" 상위 구성 요소는 prop을 통해 하위 구성 요소에 데이터(값 전달)를 보냅니다. 2. "부모에게 아들"; 자식 구성 요소는 "이벤트"를 통해 부모 구성 요소에 메시지를 보냅니다. 3. "비상위-하위 값 전송", 값을 전송하기 위한 중간 창고 역할을 하기 위해 비상위-하위 구성 요소 간에 공통 공용 인스턴스 파일 "bus.js"를 정의해야 합니다.

Vue에서 값을 전달하는 세 가지 방법은 무엇입니까?

이 튜토리얼의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.

Vue에서 일반적으로 사용되는 세 가지 값 전달 방법:

  • Father-to-son

  • Son-to-father

  • Non-parent-to-son 값 전달

공식 홈페이지 인용: 부모-자식 컴포넌트 관계는 props가 아래로 전달되고, event가 위로 전달되는 것으로 요약될 수 있습니다. 부모 컴포넌트는 props를 통해 자식 컴포넌트에 데이터를 보내고, 자식 컴포넌트는 이벤트를 통해 부모 컴포넌트에 메시지를 보냅니다.

1. 상위 구성 요소가 하위 구성 요소에 값을 전달합니다:

상위 구성 요소:

<template>
  <div>
    父组件:
    <input type="text" v-model="name">
    <br>
    <br>
    <!-- 引入子组件 -->
    <child :inputName="name"></child>
  </div>
</template>
<script>
 import child from &#39;./child&#39;
 export default {
    components: {
      child
    },
    data () {
      return {
        name: &#39;&#39;
      }
    }
  }
</script>
로그인 후 복사

하위 구성 요소:

<template>
  <div>
    子组件:
    <span>{{inputName}}</span>
  </div>
</template>
<script>
  export default {
    // 接受父组件的值
    props: {
      inputName: String,
      required: true
    }
  }
</script>
로그인 후 복사

2 하위 구성 요소가 상위 구성 요소에 값을 전달합니다:

하위 구성 요소:

<template>
  <div>
    子组件:
    <span>{{childValue}}</span>
    <!-- 定义一个子组件传值的方法 -->
    <input type="button" value="点击触发" @click="childClick">
  </div>
</template>
<script>
  export default {
    data () {
      return {
        childValue: &#39;我是子组件的数据&#39;
      }
    },
    methods: {
      childClick () {
        // childByValue是在父组件on监听的方法
        // 第二个参数this.childValue是需要传的值
        this.$emit(&#39;childByValue&#39;, this.childValue)
      }
    }
  }
</script>
로그인 후 복사

Parent 구성 요소:

<template>
  <div>
    父组件:
    <span>{{name}}</span>
    <br>
    <br>
    <!-- 引入子组件 定义一个on的方法监听子组件的状态-->
    <child v-on:childByValue="childByValue"></child>
  </div>
</template>
<script>
  import child from &#39;./child&#39;
  export default {
    components: {
      child
    },
    data () {
      return {
        name: &#39;&#39;
      }
    },
    methods: {
      childByValue: function (childValue) {
        // childValue就是子组件传过来的值
        this.name = childValue
      }
    }
  }
</script>
로그인 후 복사

3. 상위가 아닌 구성 요소와 하위 구성 요소 간의 값 전송:

상위가 아닌 구성 요소와 하위 구성 요소 간에 값을 전송하려면 공용 공용 인스턴스 파일인 버스.js를 중간 매개변수로 정의해야 합니다. 그렇지 않으면 구성 요소를 라우팅하여 가치 이전 효과를 얻을 수 없습니다.

Publicbus.js

//bus.js
import Vue from &#39;vue&#39;
export default new Vue()
로그인 후 복사

컴포넌트 A:

<template>
  <div>
    A组件:
    <span>{{elementValue}}</span>
    <input type="button" value="点击触发" @click="elementByValue">
  </div>
</template>
<script>
  // 引入公共的bug,来做为中间传达的工具
  import Bus from &#39;./bus.js&#39;
  export default {
    data () {
      return {
        elementValue: 4
      }
    },
    methods: {
      elementByValue: function () {
        Bus.$emit(&#39;val&#39;, this.elementValue)
      }
    }
  }
</script>
로그인 후 복사

컴포넌트 B:

<template>
  <div>
    B组件:
    <input type="button" value="点击触发" @click="getData">
    <span>{{name}}</span>
  </div>
</template>
<script>
  import Bus from &#39;./bus.js&#39;
  export default {
    data () {
      return {
        name: 0
      }
    },
    mounted: function () {
      var vm = this
      // 用$on事件来接收参数
      Bus.$on(&#39;val&#39;, (data) => {
        console.log(data)
        vm.name = data
      })
    },
    methods: {
      getData: function () {
        this.name++
      }
    }
  }
</script>
로그인 후 복사

관련 권장 사항: "vue.js Tutorial"

위 내용은 Vue에서 값을 전달하는 세 가지 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!