Vue组件通信

最近在学习Vue,组件化后不同组件之间如何通信,记录一下。

  • Vue中组件通信时,数据流只能由父级传递给子级,通过props,子级传递信息给父级,通过$emit。
  • 只有父子间能直接通信,兄弟(同级)之间,爷孙(隔代)之间都不能直接传递信息,只能利用父子通信来传递。

父子组件

子组件接受父组件的数据时,通过定义props来实现。子组件对父组件传递信息时,通过事件来传递。如下面的示例

http://js.jirengu.com/zuzikasoxe/2/edit

  <div id="app">
    <child :title="message" @click-child="message2 += $event "></child>
    {{message2}}
  </div>

Vue.component('child',{
  props:['title'],
  data(){
    return{
      msg: '+child发出的数据',
    }
  },
  template:`<div>
      <hr><div>
      {{title}}<button @click="$emit('click-child',msg)">child</button>
      <hr>
  </div>
  `
})
let app = new Vue({
  el: "#app",
  data: {
    message: '父组件的一个数据',
    message2: 'Hello',
  },
})
父子组件通信

子组件中通过props中的title,绑定了父组件中的message,实现了数据传递。而通过$emit()将点击事件通知了父组件,实现了父子之间的通信。

爷孙通信

爷爷和孙子是不能直接通信的,只能通过爷爷传给儿子,儿子传给孙子。孙子传给儿子,儿子传给爷爷这样进行通信。

http://js.jirengu.com/jaquhoseqo/3/edit

  <div id="app">
    {{message2}}
    <child :title="message" @click-add="message2 += $event" @click-grand-add="message2 += $event"></child>
  </div>
Vue.component('child', {
  props: ['title'],
  data() {
    return {
      msg: '+child发出的数据',
    }
  },
  template: `
  <div>
      <hr>
      {{title}}
      <button @click="$emit('click-add',msg)">child++</button>
      <grand-son :tit="title" @click-grand-add="$emit('click-grand-add',$event)"></grand-son>
  </div>
  `
})

Vue.component('grand-son', {
  props: ['tit'],
  data() {
    return {
      msg: '+grandSon发出的数据',
    }
  },
  template: `
  <div>
    <hr>
    {{tit}}
    <button @click="$emit('click-grand-add',msg)">grandSon++</button>
  </div>
  `
})

let app = new Vue({
  el: "#app",
  data: {
    message: '父组件的一个数据',
    message2: 'Hello',
  },
})
爷孙组件的通信.png

儿子通过props得到爷爷的数据,孙子再通过props得到儿子的数据,进而得到爷爷的数据。孙子发出数据时,$emit首先通知到儿子,再通知到爷爷,最后爷爷进行相应操作。

兄弟(同级)组件间通信

定义一个公共的vue实例,一个组件传递数据时,向这个实例发送$emit通知,另一个组建用这个实例监听事件,进行相应的操作。

https://jsfiddle.net/50wL7mdz/527445/

<script src="https://unpkg.com/vue"></script>

<div id="app">
  {{message}}
  <child></child>
  <child2></child2>
</div>
let bus = new Vue()

Vue.component('child', {
  props: ['title'],
  template: `
  <div>
      <hr>这里是child1
      <button @click="fn">关闭button2</button>
  </div>
  `,
  methods: {
    fn(){
        bus.$emit('click-child','child1想关闭child2')
    }
  }
})

Vue.component('child2', {
  props: ['title'],
  data() {
    return {
      msg: '这里是child2',
    }
  },
  created: function() {
    bus.$on('click-child',this.fn)
  },
  methods: {
    fn(value){
        this.msg += value
    }
  },
  template: `
  <div>
      <hr>{{msg}}
      <button>button2</button>
  </div>
  `
})

let app = new Vue({
  el: "#app",
  data: {
    message: 'Hello',
  },
})
兄弟组件通信

这段代码中bus就是一个公共的容器,使同级的兄弟组件中进行通信。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,470评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,393评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,577评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,176评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,189评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,155评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,041评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,903评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,319评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,539评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,703评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,417评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,013评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,664评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,818评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,711评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,601评论 2 353

推荐阅读更多精彩内容

  • 子组件=》父组件 vue的组件之间的通信类似angular的父子层级之间通信,父组件获取子组件数据步骤大概如下: ...
    羊烊羴阅读 339评论 0 3
  • Vue组件通信 Vue组件关系可分为三大类: 父子组件 兄弟组件 跨级组件, 相应的组件之间的通信也分类三大类: ...
    dino小恐龙阅读 1,908评论 0 2
  • 参考自vue.js 官方文档 如果你使用 Vue 进行开发的话,你不得不了解的一项就是 Vue 的组件(Compo...
    寿木阅读 371评论 0 2
  • 组件通信各种情况总结VUE是以数据驱动的MVVM框架,又是模块化开发,所以各个组件间的通信传递数据非常重要,在项目...
    流年_338f阅读 578评论 0 2
  • 父组件传递数据给子组件 父组件数据如何传递给子组件呢?可以通过props属性来实现父组件://这里必须要用 - 代...
    via_98cc阅读 134评论 1 0