2.Vue子组件给父组件通信

Posted homehtml

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2.Vue子组件给父组件通信相关的知识,希望对你有一定的参考价值。

子组件给父组件通信

如果子组件想要改变数据呢?这在vue中是不允许的,因为vue只允许单向数据传递,这时候我们可以通过触发事件来通知父组件改变数据,从而达到改变子组件数据的目的

子组件:

<template>
  <div @click=‘upData‘></div>  
</template>

<script type="text/javascript">
  export default {
    data () {
      return {
          msg: ‘Hello‘
      }
    }    
    methods: {
      upData () {
          this.$emit(‘childData‘, this.msg) //this.msg传递的数据
      }
    }
  }
</script>

<style type="text/css">
</style>

通过绑定事件upData,在里面使用$emit事件来注册childData事件,并且传递数值this.msg到父组件中
父组件:

<template>
  <child @upData=‘changData‘ :msg=‘msg‘></child>  //监听子组件触发的事件,然后调用change方法
</template>

<script type="text/javascript">
  export default {
    data () {
      return {
        msg: ‘‘
      }
    }    
    methods: {
      changData (msg) {
          this.msg = msg
      }
    }
  }
</script>

<style type="text/css">
</style>

父组件通过监听子组件的childData的事件,来触发自己的绑定的changData事件,并将值获取复制给自己的msg
到这里就完成了子组件给父组件传递数据的过程



以上是关于2.Vue子组件给父组件通信的主要内容,如果未能解决你的问题,请参考以下文章

vue实现组件通信的5中方式

关于Angular2组件通信---自己的一点总结

23组件之间的通信(练习)

vue组件通信那些事儿

vue的三种通信方式

vue2.0 组件通信