转自:http://blog.csdn.net/qq_27346299/article/details/78540751#vue之父子兄弟组件间通信
导言
最近在写个人简历网页版遇到一个问题,想要将一个组件的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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
创建字组件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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
子组件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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
运行结果如图
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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
父组件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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
结果如下
还有另一种方法与兄弟组件通信方式相同用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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
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>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
结果如图
子组件向父组件传递数据也可以使用这种方法,仿兄弟组件通信即可
参考文章
vue.js之路(4)——vue2.0s中eventBus实现兄弟组件通信