Vue2.0中如何实现组件间数据交互和通信操作?
- 内容介绍
- 文章标签
- 相关推荐
本文共计513个文字,预计阅读时间需要3分钟。
Vue2.0组件间数据交互与通信操作示例:本文介绍了Vue2.0实现组件间数据交互和通信的方法。Vue2.0摒弃了dispatch和$broadcast,转而采用事件驱动的方式实现组件间的数据传递。
Vue2.0组件间数据交互和通信:
1.使用自定义事件进行父子组件通信
2.使用$emit和$v-on实现子组件向父组件传递数据
3.使用props和$emit实现父子组件双向绑定
4.使用provide/inject实现跨组件层级的通信
具体示例:
+ Vue2.0组件间数据交互和通信+ Vue2.0组件间通信方式:props和$emit+ Vue2.0父子组件通信示例+ Vue2.0跨组件层级通信示例本文实例讲述了Vue2.0实现组件之间数据交互和通信操作。分享给大家供大家参考,具体如下:
Vue2.0组件之间数据交互和通信。
Vue2.0废弃了dispatch 和 $broadcast,如何在实现组件之间的数据交互和通信?下面是一个简单的demo解决了这个问题。
事件中心(evengtHub.js):
//定义事件中心,在模板通信是使用。 import Vue from 'vue'; export default { bus: new Vue() }
父组件:
<div> <!--msg必须跟子组件的msg参数一致,@msg是子组件向父组件传参数的接口,:msg是父组件向子组件传参数的接口--> <child1 @msg='getMsg' :msg1='msg1'></child1> <child1 ref='child2'></child2> <div>
<script> import bus form 'eventHub' componets: { child1: require('child1'), child2: require('child2'); }, data() { return: { msg1: 'hello' } }, methods: { getMsg(el) { this.$refs.child2.drop(el); //父组件调用child2组件的drop方法,传递el参数,子组件和子组件之间的通信 } } </script>
子组件1
<template> <div class='child1' @click='sendMsg'>{{msg}}<div> </template>
<script> import bus form 'eventHub'; //props属性用于子组件接收父组件传过来的参数 props: { msg1 :String }, methods: { this.bus.$emit('add', event.target);//此方法可以通过子组件1在任意组件内响应点击事件。 this.$emit('msg', event.target);//发送数据给父组件,这个方法的'msg'参数必须和父组件的@msg保持一致。 } </script>
子组件2
<template> <div class='child2'><div> </template>
<script> import bus form 'eventHub' methods: { drop(el) { console.log(el);//打印出child1的div元素 } }, created() { this.bus.$on('add',() => { console.log('响应child1的点击事件'); }) } </script>
上面的例子中包括父子组件之间互相传参数和组件之间的通信,更好的组件通信事件请使用vuex。
希望本文所述对大家vue.js程序设计有所帮助。
本文共计513个文字,预计阅读时间需要3分钟。
Vue2.0组件间数据交互与通信操作示例:本文介绍了Vue2.0实现组件间数据交互和通信的方法。Vue2.0摒弃了dispatch和$broadcast,转而采用事件驱动的方式实现组件间的数据传递。
Vue2.0组件间数据交互和通信:
1.使用自定义事件进行父子组件通信
2.使用$emit和$v-on实现子组件向父组件传递数据
3.使用props和$emit实现父子组件双向绑定
4.使用provide/inject实现跨组件层级的通信
具体示例:
+ Vue2.0组件间数据交互和通信+ Vue2.0组件间通信方式:props和$emit+ Vue2.0父子组件通信示例+ Vue2.0跨组件层级通信示例本文实例讲述了Vue2.0实现组件之间数据交互和通信操作。分享给大家供大家参考,具体如下:
Vue2.0组件之间数据交互和通信。
Vue2.0废弃了dispatch 和 $broadcast,如何在实现组件之间的数据交互和通信?下面是一个简单的demo解决了这个问题。
事件中心(evengtHub.js):
//定义事件中心,在模板通信是使用。 import Vue from 'vue'; export default { bus: new Vue() }
父组件:
<div> <!--msg必须跟子组件的msg参数一致,@msg是子组件向父组件传参数的接口,:msg是父组件向子组件传参数的接口--> <child1 @msg='getMsg' :msg1='msg1'></child1> <child1 ref='child2'></child2> <div>
<script> import bus form 'eventHub' componets: { child1: require('child1'), child2: require('child2'); }, data() { return: { msg1: 'hello' } }, methods: { getMsg(el) { this.$refs.child2.drop(el); //父组件调用child2组件的drop方法,传递el参数,子组件和子组件之间的通信 } } </script>
子组件1
<template> <div class='child1' @click='sendMsg'>{{msg}}<div> </template>
<script> import bus form 'eventHub'; //props属性用于子组件接收父组件传过来的参数 props: { msg1 :String }, methods: { this.bus.$emit('add', event.target);//此方法可以通过子组件1在任意组件内响应点击事件。 this.$emit('msg', event.target);//发送数据给父组件,这个方法的'msg'参数必须和父组件的@msg保持一致。 } </script>
子组件2
<template> <div class='child2'><div> </template>
<script> import bus form 'eventHub' methods: { drop(el) { console.log(el);//打印出child1的div元素 } }, created() { this.bus.$on('add',() => { console.log('响应child1的点击事件'); }) } </script>
上面的例子中包括父子组件之间互相传参数和组件之间的通信,更好的组件通信事件请使用vuex。
希望本文所述对大家vue.js程序设计有所帮助。

