码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2019-12-01 16:45:33      阅读:66      评论:0      收藏:0      [点我收藏+]

标签:click   目的   数据   使用   template   改变   def   default   class   

子组件给父组件通信

如果子组件想要改变数据呢?这在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子组件给父组件通信

标签:click   目的   数据   使用   template   改变   def   default   class   

原文地址:https://www.cnblogs.com/homehtml/p/11966253.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!