Maison > interface Web > Voir.js > Quels sont les moyens de transmettre des valeurs dans Vue ?

Quels sont les moyens de transmettre des valeurs dans Vue ?

藏色散人
Libérer: 2023-01-13 00:45:25
original
11731 Les gens l'ont consulté

Les méthodes de transfert de valeur de Vue incluent : 1. les accessoires sont transmis vers le bas et les événements sont transmis vers le haut ; 2. les composants enfants déclenchent des événements personnalisés des composants parents via $emit 3. le transfert entre les composants non parents et enfants en définissant la valeur des fichiers d'instance publics ; .

Quels sont les moyens de transmettre des valeurs dans Vue ?

L'environnement d'exploitation de cet article : système windows7, vue version 2.5.17, ordinateur DELL G3.

Quelles sont les méthodes de transmission de valeurs dans Vue ?

Trois méthodes de transmission de valeurs couramment utilisées dans Vue

Parent à enfant

La relation entre les composants parent-enfant peut être résumée comme suit les accessoires sont transmis vers le bas et les événements vers le haut. Le composant parent envoie des données au composant enfant via des accessoires, et le composant enfant envoie des messages au composant parent via des événements.

Composant Parent :

<template>
  <p>
    父组件:
    <input type="text" v-model="name">
    <br>
    <br>
    <!-- 引入子组件 -->
    <child :inputName="name"></child>  //child子组件通过 :inputName="name" 将值传过去
  </p>
</template>
<script>
  import child from './child'
  export default {
    components: {
      child
    },
    data () {
      return {
        name: ''
      }
    }
  }
</script>
Copier après la connexion

Composant Enfant :

<template>
  <p>
    子组件:
    <span>{{inputName}}</span>
  </p>
</template>
<script>
  export default {
    // 接受父组件的值
    props: {
      inputName: String,   //在这里对传过来的进行接收
      required: true
    }
  }
</script>
Copier après la connexion

Du fils au parent

Les composants enfants peuvent déclencher des événements personnalisés du composant parent via $emit. vm.$emit(event,arg) est utilisé pour déclencher des événements sur l'instance actuelle

composant enfant :

<template>
  <p>
    子组件:
    <span>{{childValue}}</span>
    <!-- 定义一个子组件传值的方法 -->
    <input type="button" value="点击触发" @click="childClick">
  </p>
</template>
<script>
  export default {
    data () {
      return {
        childValue: '我是子组件的数据'
      }
    },
    methods: {
      childClick () {
        // childByValue是在父组件on监听的方法
        // 第二个参数this.childValue是需要传的值
        this.$emit('childByValue', this.childValue)  
      }
    }
  }
</script>
Copier après la connexion

composant parent :

<template>
  <p>
    父组件:
    <span>{{name}}</span>
    <br>
    <br>
    <!-- 引入子组件 定义一个on的方法监听子组件的状态-->
    <child v-on:childByValue="childByValue"></child>
  </p>
</template>
<script>
  import child from './child'
  export default {
    components: {
      child
    },
    data () {
      return {
        name: ''
      }
    },
    methods: {
      childByValue: function (childValue) {
        // childValue就是子组件传过来的值
        this.name = childValue
      }
    }
  }
</script>
Copier après la connexion

composant non parent-enfant transmettant une valeur

passant une valeur entre Composants non parent-enfant, vous devez définir un fichier d'instance public bus.js comme entrepôt intermédiaire pour transférer les valeurs, sinon l'effet de transfert de valeur entre les composants de routage ne sera pas obtenu.

Public bus.js

//bus.js
import Vue from 'vue'
export default new Vue()
Copier après la connexion

Composant A :

<template>
  <p>
    A组件:
    <span>{{elementValue}}</span>
    <input type="button" value="点击触发" @click="elementByValue">
  </p>
</template>
<script>
  // 引入公共的bug,来做为中间传达的工具
  import Bus from './bus.js'
  export default {
    data () {
      return {
        elementValue: 4
      }
    },
    methods: {
      elementByValue: function () {
        Bus.$emit('val', this.elementValue)
      }
    }
  }
</script>
Copier après la connexion

Composant B :

<template>
  <p>
    B组件:
    <input type="button" value="点击触发" @click="getData">
    <span>{{name}}</span>
  </p>
</template>
<script>
  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++
      }
    }
  }
</script>
Copier après la connexion

Recommandations associées : "tutoriel vue.js" "Les 5 dernières sélections de didacticiels vidéo vue.js"

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
vue
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal