源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Vue2.x中的父子组件相互通信的实现方法

  • 时间:2021-12-27 10:05 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Vue2.x中的父子组件相互通信的实现方法
业务场景:(这里指的是直接父子级关系的通信) [list] [*]美女(子组件)将消息发送给大群(父组件)[/*] [*]大群(父组件)收到美女发送的消息后再回个信息给美女(子组件)[/*] [/list] [b]父组件[/b] [b]template[/b]
<template>
  <div>
    <p>群消息girl:</p>
    <div>
      {{ somebody }} 说: 我 {{ age }} 了。
    </div>
    <hr>
    <v-girl-group 
        :girls="aGirls" 
        :noticeGirl="noticeGirl"
        @introduce="introduceSelf"></v-girl-group>
  </div>
</template>
[b]注意的点:[/b] [list] [*]这里在父组件使用v-on来监听子组件上的自定义事件($emit的变化),一旦发生变化noticeGirl方法就会触发[/*] [/list]
<script>
import vGirlGroup from './GirlGroup'
export default {
  name: 'girl',
  components: {
    vGirlGroup
  },
  data () {
    return {
      aGirls:[{
        name:'小丽',
        age:22
      },{
        name:'小美',
        age:21
      },{
        name:'小荷',
        age:24
      }],
      somebody:'',
      age:'',
      noticeGirl:''
    }
  },
  methods: {
    introduceSelf (opt) {
      this.somebody = opt.name;
      this.age = opt.age;
      // 通知girl收到消息
      this.noticeGirl = opt.name + ',已收到消息';
    }
  }
}
</script>
[b]注意的点:[/b] 这里methods中定义的方法introduceSelf就是父组件接收到子组件发出的$emit的事件处理程序 [b]子组件[/b] [b]template[/b]
<template>
  <div>
    <ul>
      <li v-for="(value, index) in girls">
        {{ index }} - {{ value.name }} - {{ value.age }} 
        <button @click="noticeGroup(value.name,value.age)">发送消息</button>
      </li> 
    </ul>
    <div>接收来自大群的消息:{{ noticeGirl }}</div>
  </div>
</template>
[b]script[/b]
<script>
export default {
  name: 'girl-group',
  props: {
    girls: {
      type: Array,
      required: true
    },
    noticeGirl: {
      type: String,
      required: false
    }
  },
  methods: {
    noticeGroup (name, age) {
      this.$emit('introduce',{
        name: name,
        age: age
      })
    }
  }
}
</script>
[b]注意的点:[/b] 子组件使用$emit发出自定义事件 相比于Vue1.x的变化: $dispatch 和 $broadcast 已经被弃用 *官方推荐的通信方式 首选使用Vuex 使用事件总线:eventBus,允许组件自由交流 具体可见:[url=https://cn.vuejs.org/v2/guide/migration.html#dispatch]https://cn.vuejs.org/v2/guide/migration.html#dispatch[/url]-和-broadcast-替换 结果 [img]http://files.jb51.net/file_images/article/201705/2017050210291134.png[/img] [img]http://files.jb51.net/file_images/article/201705/2017050210291135.png[/img] [img]http://files.jb51.net/file_images/article/201705/2017050210291136.png[/img] 以上所述是小编给大家介绍的Vue2.x中的父子组件相互通信,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部