ホームページ  >  記事  >  ウェブフロントエンド  >  Vueで値を渡す3つの方法は何ですか?

Vueで値を渡す3つの方法は何ですか?

青灯夜游
青灯夜游オリジナル
2021-09-06 12:03:553669ブラウズ

Vue には 3 つの値渡しメソッドがあります: 1. 「父から子」; 親コンポーネントは、prop を通じて子コンポーネントにデータを渡します (値渡し)。 2. 「息子から親へ」; 子コンポーネントは「イベント」を通じて親コンポーネントにメッセージを送信します。 3. 「非親子値転送」; 値を転送するための中間ウェアハウスとして機能するために、非親子コンポーネント間で共通のパブリック インスタンス ファイル「bus.js」を定義する必要があります。

Vueで値を渡す3つの方法は何ですか?

このチュートリアルの動作環境: Windows7 システム、vue2.9.6 バージョン、DELL G3 コンピューター。

#Vue で一般的に使用される 3 つの値渡しメソッド:

  • 父から子への受け渡し

  • 息子から父親への受け渡し

  • 父親以外から息子への値渡し

##引用公式ウェブサイトより: 親コンポーネントと子コンポーネントの関係は、Props が受け渡され、イベントが受け渡されると要約できます。親コンポーネントは 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>

親コンポーネント:

<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. 非-親子コンポーネントの値の転送:

親以外のコンポーネントと子コンポーネントの間で値を転送するには、転送する中間ウェアハウスとして共通のパブリック インスタンス ファイル Bus.js を定義する必要があります。値を渡すと、ルーティング コンポーネントが相互に到達できなくなります。

パブリックバス.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チュートリアル###"###

以上がVueで値を渡す3つの方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。