详解利用eventemitter2实现Vue组件通信

《详解利用eventemitter2实现Vue组件通信》

概述

Vue.js 是一款建立在MVVM模式之上的框架,而在 Vue.js 应用开发中,组件通信是不可避免的。尽管Vue.js提供了许多方式来实现组件通信,使用EventEmitter2来实现组件通信能够更好的解耦组件,提高组件的复用性。

EventEmitter2 是 EventEmitter 的一个强化版,提供了更多的功能并支持命名空间。这些特性正好可以解决Vue.js中组件通信的各类问题,是一个非常实用的方案。

安装 eventemitter2

在Vue.js之外安装 eventemitter2:

npm install eventemitter2

在Vue.js中引入 eventemitter2:

import EventEmitter2 from 'eventemitter2'
const emitter = new EventEmitter2();
export default emitter;

在组件中,我们可以通过import将上述模块引入:

import emitter from './EventEmitter'

以上等价于:

import EventEmitter2 from 'eventemitter2'
const emitter = new EventEmitter2();
export default emitter;

监听事件

在组件中监听事件:

emitter.on('change', data => {
  console.log(data);
});

触发事件

在组件中触发事件:

emitter.emit('change', 'hello world');

示例说明

下面将介绍两个示例说明运用 eventemitter2 实现Vue组件通信。

示例一:父组件向子组件通信

在子组件中监听‘getmessage’事件:

emitter.on('getmessage', message => {
  this.message = message;
});

在父组件中触发‘getmessage’事件:

emitter.emit('getmessage', 'hello world');

示例二:子组件向父组件通信

在子组件中触发‘setmessage’事件:

this.$emit('setmessage', 'hello world');

在父组件中监听‘setmessage’事件:

<child-component @setmessage="setMessage"></child-component>
...
methods: {
  setMessage(message) {
    this.message = message;
  }
}

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:详解利用eventemitter2实现Vue组件通信 - Python技术站

(0)
上一篇 2023年5月29日
下一篇 2023年5月29日

相关文章

  • 带你理解vue中的v-bind

    当使用 Vue.js 开发页面时,我们常常需要给 HTML 元素动态绑定属性或者是事件,这个时候就需要使用到 v-bind 指令。v-bind 可以用来动态绑定 HTML 属性,甚至是自定义属性。 使用方法 v-bind 指令可以缩写成简洁的冒号绑定形式。使用方法如下: <template> <div> <!– 完整语法 –…

    Vue 2023年5月28日
    00
  • Vue.JS入门教程之自定义指令

    下面我就为你详细讲解 Vue.JS 入门教程之自定义指令的完整攻略。 什么是自定义指令 Vue.JS 中的指令是一种特殊的标记,可以在模板中使用,用于对 HTML 元素进行特殊处理。Vue.JS 提供了一些内建指令(例如 v-if、v-for、v-bind 等),同时也提供了自定义指令的功能,允许开发者自己定义指令来扩展 Vue.JS 的功能。 自定义指令通…

    Vue 2023年5月27日
    00
  • 深入理解Vue父子组件生命周期执行顺序及钩子函数

    下面是“深入理解Vue父子组件生命周期执行顺序及钩子函数”的完整攻略: 什么是Vue组件生命周期? Vue组件是Vue.js中最重要的概念之一。一个Vue组件可以看作是一个拥有预定义选项的Vue实例。与Vue实例一样,Vue组件也有它们自己的生命周期。Vue组件的生命周期包括创建、挂载、更新和销毁四个阶段。 为了更好地理解Vue组件生命周期,我们需要明确每个…

    Vue 2023年5月28日
    00
  • Vue高级组件之函数式组件的使用场景与源码分析

    下面是Vue高级组件之函数式组件的使用场景与源码分析的详细攻略: 什么是函数式组件? 函数式组件在Vue2.3版本中引入的新特性,可以提高组件的性能和减少不必要的组件实例化。它是一种纯函数,接受一个props对象并返回渲染的虚拟DOM。它没有状态(即数据驱动),也没有实例,所以没有生命周期函数,仅仅是一个接收props并返回渲染vnode的函数。使用函数式组…

    Vue 2023年5月28日
    00
  • 详解.vue文件中style标签的几个标识符

    当我们使用 Vue 开发前端项目时,Vue 的单文件组件 .vue 文件中允许我们在 <template> 标签中定义模板、在 <script> 标签中定义 JS 代码、在 <style> 标签中定义 CSS 样式。对于 <style> 标签,Vue 允许我们使用一些特殊的标识符来扩展它们的功能和特性。 下面是…

    Vue 2023年5月28日
    00
  • Vue项目配置router.js流程分析讲解

    Vue项目可以使用Vue Router来实现页面的路由管理。在配置Vue项目中使用Vue Router,需要在项目中引入Vue Router并在router.js文件中进行路由的配置。下面是Vue项目配置router.js的详细攻略: 安装Vue Router 在Vue项目中使用Vue Router 需要先安装Vue Router。可以使用npm来进行安装,…

    Vue 2023年5月28日
    00
  • vue中关于_ob_:observer的处理方式

    在 Vue 中,ob 是一个内部属性,用于标记一个对象是否已被 Vue 的观察者系统观察。当把一个对象传递给 Vue 实例后,Vue 会通过响应式的方式将这个对象转化成 getter/setter 对象,并在 ob 属性中添加一个标记,以便后续的处理。 如果一个数据对象被多个 Vue 实例中的 JSON.stringify 或 $watch 观察,那么就会引…

    Vue 2023年5月28日
    00
  • vue cli升级webapck4总结

    首先需要了解的是Vue CLI是一个Vue.js的脚手架,用于快速搭建基于Vue.js的单页应用程序。Vue CLI 3是最新版本,其默认使用Webpack 4作为构建工具。 升级Vue CLI的过程可以分成以下几个步骤: 步骤一:检查当前Vue CLI版本 首先需要检查当前项目中所使用的Vue CLI版本,可以在Terminal里输入以下命令: vue -…

    Vue 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部