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

yizhihongxing

《详解利用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日

相关文章

  • vuex的辅助函数该如何使用

    Vuex是一个专为Vue.js应用程序开发的状态管理模式。Vuex的辅助函数提供了一种简化使用Vuex的方法。本文将详细介绍Vuex辅助函数的使用方法,以及两个示例的说明。 关于Vuex辅助函数 Vuex的辅助函数本质上是基于Vuex Store的全局getState、commit、dispatch和mapState、mapGetters、mapMutati…

    Vue 2023年5月28日
    00
  • axios封装,使用拦截器统一处理接口,超详细的教程(推荐)

    axios封装,使用拦截器统一处理接口,超详细的教程 为什么需要封装、使用拦截器统一处理接口? 在实际开发中,我们经常会使用到Ajax技术,而Axios是一个比较好用的Ajax库。但是,使用 Axios 发送请求的时候,我们遇到的一些问题: 大量重复代码:每次请求都要写一堆重复的代码,如设置 headers,处理错误等。 统一处理后端返回的数据:由于每个接口…

    Vue 2023年5月28日
    00
  • 详解template标签用法(含vue中的用法总结)

    详解template标签用法(含vue中的用法总结) 简介: <template> 标签是一个通用的占位符元素,可以作为组件的模板,也可以作为一段代码片段,使你可以在渲染这段代码片段时,避免包含在页面中。这个标签在Vue的使用中尤其重要,在Vue的单文件组件中大量使用,尤其是作为组件的模板。 基本用法: <template> 标记的作…

    Vue 2023年5月28日
    00
  • Vue组件间的通信pubsub-js实现步骤解析

    下面我将详细讲解“Vue组件间的通信pubsub-js实现步骤解析”。 什么是pubsub-js? pubsub-js是一个基于发布/订阅模式的Javascript库,提供了一种解耦的方式,让我们的代码更加灵活和易于维护。在Vue组件间的通信中,我们可以使用pubsub-js来实现跨组件的数据传递。 pubsub-js的安装 我们可以使用npm或yarn在项…

    Vue 2023年5月28日
    00
  • vue-cli3 项目优化之通过 node 自动生成组件模板 generate View、Component

    下面是详细讲解 vue-cli3 项目优化之通过 node 自动生成组件模板 generate View、Component 的完整攻略。 1. 什么是 vue-cli3? Vue CLI 是一个官方发布的 Vue.js 项目脚手架,提供了标准化、插件化的 Vue 项目开发体验。vue-cli3 是 Vue CLI 的第三个版本,相较于前两个版本,vue-c…

    Vue 2023年5月28日
    00
  • 前端vue3使用axios调用后端接口的实现方法

    当前端使用Vue3框架时,常常需要通过HTTP请求与后端进行交互从而实现前后端数据的交互。而axios作为一个基于Promise的HTTP客户端,已经成为前端开发中最常用的HTTP请求工具之一。下面是Vue3前端使用axios调用后端接口的实现方法攻略: 1. 安装axios 使用npm可以很容易地安装axios,只需要在项目根目录下运行以下命令即可: np…

    Vue 2023年5月27日
    00
  • 一键将Word文档转成Vue组件mammoth的应用详解

    一键将Word文档转成Vue组件Mammoth的应用详解 简介 Mammoth是一个将Word文档转换成HTML文档的Python工具。我们可以利用它将Word文档转换成Vue组件代码,在Vue项目中直接使用,这将大大提高前端人员的效率,减少手动编写Vue组件的时间。 步骤 以下是一步一步将Word文档转换成Vue组件的操作步骤: 1.安装Mammoth 在…

    Vue 2023年5月27日
    00
  • 如何在vue3.0+中使用tinymce及实现多图上传文件上传公式编辑功能

    下面我为你详细讲解如何在Vue 3.0+中使用TinyMCE并实现多图上传、文件上传、公式编辑等功能。 准备工作 首先,我们需要安装@tinymce/tinymce-vue插件: npm install –save @tinymce/tinymce-vue 然后,我们需要在Vue项目的main.js中引入@tinymce/tinymce样式文件: impo…

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