Vue2.0中如何实现组件间数据交互和通信操作?

2026-04-09 17:281阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计513个文字,预计阅读时间需要3分钟。

Vue2.0中如何实现组件间数据交互和通信操作?

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组件之间数据交互和通信。

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实现组件间数据交互和通信的方法。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组件之间数据交互和通信。

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程序设计有所帮助。