>웹 프론트엔드 >View.js >Vue에서 값을 전달하는 세 가지 방법은 무엇입니까?

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

青灯夜游
青灯夜游원래의
2021-09-06 12:03:553751검색

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:

d477f9ce7bf77f53fbcf36bec1b69b7a
  dc6dce4a544fdca2df29d5ac0ea9906b
    B组件:
    db522d5eab17920485b61ce7362da4b9
    45a2772a6b6107b401db3c9b82c049c2{{name}}54bdf357c58b8a65c66d7c19c8e4d114
  16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2
3f1c4e4b6b16bbbd69b2ee476dc4f83a
  import Bus from './bus.js'
  export default {
    data () {
      return {
        name: 0
      }
    },
    mounted: function () {
      var vm = this
      // 用$on事件来接收参数
      Bus.$on('val', (data) => {
        console.log(data)
        vm.name = data
      })
    },
    methods: {
      getData: function () {
        this.name++
      }
    }
  }
2cacc6d41bbb37262a98f745aa00fbf0

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

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

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