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

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

青灯夜游
リリース: 2023-01-13 00:45:25
オリジナル
3746 人が閲覧しました

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:

<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チュートリアル###"###

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

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート