关闭

Vue之父子兄弟组件间通信

标签: javascript
189人阅读 评论(0) 收藏 举报
分类:

Vue之父子兄弟组件间通信

@(JavaScript)[学习笔记]



导言

最近在写个人简历网页版遇到一个问题,想要将一个组件的dom结构传递给其他兄弟组件,然后进行dom操作,不知怎么在其间传递数据,查阅资料,找到解决方法,现记录如下,整理思路加强学习,同时便于他人参考
创建一个App.vue作为父组件

<template>
  <div class="app">
    <childA></childA>
    <childB></childB>
  </div>
</template>

<script type="text/ecmascript-6">
  import childA from './components/A.vue'
  import childB from './components/B.vue'

  export default {
    components: {
      childA,
      childB
    }
  }
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

创建字组件A

<template>
  <div class="child-a"></div>
</template>

<script type="text/ecmascript-6">
  export default {}
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

创建子组件B

<template>
  <div class="child-b"></div>
</template>

<script type="text/ecmascript-6">
  export default {}
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

1. 父组件向子组件传递消息

父组件向子组件传数据较为简单,子组件用props接收
父组件App

<template>
  <div class="app">
    <childA :msgApp="msgApp"></childA>
    <childB></childB>
  </div>
</template>

<script type="text/ecmascript-6">
  import childA from './components/A.vue'
  import childB from './components/B.vue'

  export default {
    data () {
      return {
        msgApp: '我是来子父组件的消息'
      }
    },
    components: {
      childA,
      childB
    }
  }
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

子组件A

<template>
  <div class="child-a">我是组件A,接收到消息:{{msgApp}}</div>
</template>

<script type="text/ecmascript-6">
  export default {
    props: {
      msgApp: {
        type: String
      }
    }
  }
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

运行结果如图
enter image description here

2. 子组件向父组件传递数据

子组件向父组件传递数据用this,$emit()
子组件B

<template>
  <div class="child-b"></div>
</template>

<script type="text/ecmascript-6">
  export default {
    data () {
      return {
        msgB: '我是来子B组件的消息'
      }
    },
    mounted () {             // 这里我选择加载完成就传递数据,也可以定义事件等
      this.$emit('msg', this.msgB)
      console.log(this.msgB)
    }
  }
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

父组件App

<template>
  <div class="app">
    <childA :msgApp="msgApp"></childA>
    <childB v-on:msg="show"></childB
    我是父组件,接受到消息:{{msgB}}
  </div>
</template>

<script type="text/ecmascript-6">
  import childA from './components/A.vue'
  import childB from './components/B.vue'

  export default {
    data () {
      return {
        msgApp: '我是来子父组件的消息',
        msgB: ''
      }
    },
    methods: {
      show (a) {
        this.msgB = a
      }
    },

    components: {
      childA,
      childB
    }
  }
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

结果如下
enter image description here
还有另一种方法与兄弟组件通信方式相同用eventBus

3. 兄弟组件间通信

兄弟组件通信用eventBus来实现
新建一个js文件,来创建出我们的eventBus,把它命名为bus.js
在组件A和组件B导入就可以使用了
bus.js

import Vue from 'vue'
export default new Vue()

A组件

<template>
  <div class="child-a">我是组件A,接收到B消息:{{msgFromB}}</div>
</template>

<script type="text/ecmascript-6">
  import bus from '../bus'
  export default {
    data () {
      return {
        msgFromB: ''
      }
    },
    mounted () {
      bus.$on('msg', (a) => {
        this.msgFromB = a
      })
    }
  }
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

B组件

<template>
  <div class="child-b">
  </div>
</template>

<script type="text/ecmascript-6">
  import bus from '../bus'
  export default {
    data () {
      return {
        msgB: '我是来子B组件的消息'
      }
    },
    mounted () {
      bus.$emit('msg', this.msgB)
    }
  }
</script>

<style lang="stylus" rel="stylesheet/stylus">
</style>

结果如图
enter image description here

子组件向父组件传递数据也可以使用这种方法,仿兄弟组件通信即可

参考文章

vue.js之路(4)——vue2.0s中eventBus实现兄弟组件通信

0
0
查看评论

Vue 兄弟组件通信(不使用Vuex)

Vue 兄弟组件通信(不使用Vuex)项目中,我们经常会遇到兄弟组件通信的情况。
  • panyang01
  • panyang01
  • 2017-07-27 22:36
  • 4743

vue2.0父子组件通信(慕课网)

vue2.0 父传子:Props 子传父:子:$emit(eventName) 父$on(eventName) 父访问子:ref 非父子组件通信 :https://vuefe.cn/guide/components.html#非父子组件通信  vue2.0 移除:1...
  • sinat_17775997
  • sinat_17775997
  • 2017-03-10 10:11
  • 867

vue2.0父子组件以及非父子组件如何通信

1.父组件传递数据给子组件父组件数据如何传递给子组件呢?可以通过props属性来实现父组件:<parent> <child :child-msg="msg"></child>//这里必须要用 - 代替驼峰 </parent>...
  • mr_fzz
  • mr_fzz
  • 2017-01-20 23:46
  • 50646

vue开发:vue2.0父子组件及非父子组件之间的通信方法

1.父组件传递数据给子组件 父组件数据如何传递给子组件呢?可以通过props属性来实现 父组件: ? 1 2 3 4 5 6 7 8   <child ...
  • Generon
  • Generon
  • 2017-07-12 09:39
  • 410

总结vue父子组件之间的通信

一 环境搭建 步骤 1 打开git,运行npm  install --global vue-cli 这是安装vue的命令行         2 vue init webpack vue-demo 这是vue基于webpack的模块项目 ...
  • Johnny0991
  • Johnny0991
  • 2017-11-15 11:03
  • 1428

Vue--兄弟级别组件之间传递参数

html> html lang="en"> head> meta charset="UTF-8"> title>Titletitle> script src="js/vue.js"...
  • guohao326
  • guohao326
  • 2017-05-27 21:01
  • 3085

vue如何实现父子组件通信,以及非父子组件通信(待看)

https://vuefe.cn/v2/guide/components.html# 非父子关系 var vm = new Vue({ el: '#list', ready: function(){ var _this = this; var url = &...
  • melody_day
  • melody_day
  • 2016-12-08 10:14
  • 2439

VueJS兄弟组件通信

on和emit的事件必须是在一个公共的实例上,才能触发。 我的解决方案是: 新建bus.js import Vue from 'vue' export var bus = new Vue() App.vue里created方法里定义事件 import { ...
  • zgrkaka
  • zgrkaka
  • 2017-06-14 13:42
  • 1402

vue2.0兄弟组件传递数据

最近在看vue2.0,感觉就一个字——坑!大大的坑!在做兄弟组件通信的时候$dispatch已经被废了啊。网上资料也都说了各种方法,也就几句代码的事,说起来简单。具体怎么用也没有详细的讲。以下是我实现的效果 import Vue from 'vue'; export defaul...
  • yongcheng0912
  • yongcheng0912
  • 2017-03-17 22:39
  • 3168

Vue 父子组件、组件间通信

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>组件</title> &...
  • H1069495874
  • H1069495874
  • 2017-03-03 11:25
  • 1852
    个人资料
    • 访问:3617次
    • 积分:227
    • 等级:
    • 排名:千里之外
    • 原创:20篇
    • 转载:0篇
    • 译文:0篇
    • 评论:0条
    文章分类
    最新评论