iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue eventBus事件总线封装后再用的方式
  • 925
分享到

Vue eventBus事件总线封装后再用的方式

2024-04-02 19:04:59 925人浏览 泡泡鱼
摘要

目录前言空Vue实例构建的事件总线简单的方式复杂又简单的方式总结前言 现在的项目中是不是在使用 eventbus 的时候,还有很多人都是直接创建一个vue 实例直接使用的,哪里需要哪

前言

现在的项目中是不是在使用 eventbus 的时候,还有很多人都是直接创建一个vue 实例直接使用的,哪里需要哪里引入,而没有简单的处理下。接下来就先说下这种方式。

空vue实例构建的事件总线

在改造一个项目的时候就发现,里面的 bus.js 文件中就是这么处理的。两行代码搞定。

import Vue from "vue"; 
export default new Vue()

使用的时候,就没那么简单了,有这么一个空的容器,在需要传值的组件里就得引入这个文件。然后通过 bus.on()绑定事件,通过bus.on() 绑定事件,通过 bus.on()绑定事件,通过bus.emit()进行分发事件。

import bus from'@/utils/bus'
// 绑定事件
bus.$on('event',()=>{....})

// 监听事件
bus.$emit('event',this.tasks)

这种方式使用起来也简单但也不太方便,毕竟到处都要引入下,那有没有什么办法可以解决呢。继续...

简单的方式

先来个简单的吧,虽然看上去有点不太习惯,但的确也挺好使的,而且直接挂载到vue实例上,哪里用哪里直接 this 即可,相对来说方便多了,不用到处引入文件了。挂载方式如下:

new Vue({
  beforeCreate() {
    // 尽量早地执行挂载全局事件总线对象的操作
    Vue.prototype.$bus = this;
  },
  router,
  store,
  render: h => h(App)
}).$mount('#app');

这种方式虽然挂载简单,但是使用上还是有点不能尽如人意,不信你看:

// 绑定事件
this.$bus.$on('send', ()=>{ // 使用事件 });

// 分发事件
this.$bus.$emit('send', 'emit');

猛地一看,这不挺好的么,挺简单的啊!可是我有洁癖怎么办,我有强迫症怎么办,我就不想看到两个 $符怎么办我就只想要下面的这种方式的:

// 绑定事件
this.$bus.on('send', ()=>{ // 使用事件 });

// 分发事件
this.$bus.emit('send', 'emit');

那你说,人家都是 $on$emit的用的,怎么就不行了啊,实在不行就自己改造个吧,说干就干,who 怕 who,安排!

复杂又简单的方式

先构思下,想要个什么样效果的,比如,我不想要用的时候都要引入下文件,要一次引入,处处可用; 我不想要两个 $ 的调用方式,或者说可以随心情的使用; 再者通过Vue对象也可以直接使用。

思路大概理了理,那就开干呗,简单干脆点,直接上代码!

'use strict';
function VueBus(Vue) {
  let bus = new Vue();

  Object.defineProperties(bus, {
    on: {
      get() {
        return this.$on.bind(this);
      }
    },
    once: {
      get() {
        return this.$once.bind(this);
      }
    },
    off: {
      get() {
        return this.$off.bind(this);
      }
    },
    emit: {
      get() {
        return this.$emit.bind(this);
      }
    }
  });

  Object.defineProperty(Vue, 'bus', {
    get() {
      return bus;
    }
  });

  Object.defineProperty(Vue.prototype, '$bus', {
    get() {
      return bus;
    }
  });
  if (typeof window !== 'undefined' && window.Vue) {
    window.Vue.use(VueBus);
  }

  return bus;
}

export default VueBus;

来看看使用方式吧,是不是跟想象的一样简单,在 main.js 中引入,并通过 vue.use() 注入进来,加载方式就这么简单。

import EventBus from '@/libs/bus';

Vue.use(EventBus);

使用上更灵活了,想怎么用就怎么用,支持以下几种方式,至于$off$once使用上通 $on$emit一样。

// 绑定事件
this.$bus.on('send', this.handleSend); // 推荐
this.$bus.$on('send', this.handleSend);
Vue.bus.on('send', this.handleSend);
Vue.bus.$on('send', this.handleSend);

// 分发事件
this.$bus.emit('send', ''); // 推荐
this.$bus.$emit('send', 'emit');
Vue.bus.emit('send', 'emit');
Vue.bus.$emit('send', 'emit');

上面这几种方式均可。是不是更灵活了呢。想怎么用就怎么用,再也不用担心会写错调用方式了。

总结

到此这篇关于Vue eventBus事件总线封装后再用的文章就介绍到这了,更多相关Vue eventBus事件总线封装内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Vue eventBus事件总线封装后再用的方式

本文链接: https://www.lsjlt.com/news/152347.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue eventBus事件总线封装后再用的方式
    目录前言空vue实例构建的事件总线简单的方式复杂又简单的方式总结前言 现在的项目中是不是在使用 eventbus 的时候,还有很多人都是直接创建一个vue 实例直接使用的,哪里需要哪...
    99+
    2024-04-02
  • Vue eventBus事件总线封装后再用怎么实现
    今天小编给大家分享一下Vue eventBus事件总线封装后再用怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2023-07-02
  • Vue中事件总线(eventBus)的深入详解及使用
    目录1. 简介2. 使用安装及引入在组件中使用补充:移除监听事件总结1. 简介 Vue 组件中常见的有:父子组件通信、兄弟组件通信。而父子组件通信就很简单,父组件会通过 props ...
    99+
    2024-04-02
  • vue篇之事件总线EventBus使用示例详解
    目录正文父子组件通讯原则EventBus的简介如何使用EventBus初始化发送事件接收事件移除事件监听者全局EventBus创建全局EventBus总结正文 许多现代JavaScr...
    99+
    2024-04-02
  • Flutter EventBus事件总线的应用详解
    目录前言EventBus的简介EventBus的实际应用总结前言 flutter项目中,有许多可以实现跨组件通讯的方案,其中包括InheritedWidget,Notificatio...
    99+
    2024-04-02
  • vue中所有的封装方式总结
    本篇内容主要讲解“vue中所有的封装方式总结”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中所有的封装方式总结”吧!目录封装API 注册全局工具组件 3.封装全局函数&...
    99+
    2023-06-20
  • 浅谈vue中所有的封装方式总结
    目录1.封装API 2.注册全局工具组件 3.封装全局函数4. 为了减少页面代码量的封装如何确定我需要封装呢? 1.复用,如果觉得以后还会用到 2.你觉...
    99+
    2024-04-02
  • Vue全局事件总线$bus安装与应用小结
    目录1.什么是全局事件总线2.安装3.使用4.销毁完整版示例:1.什么是全局事件总线 一种组件间通信的方式,适用于任意组件间通信。 2.安装 在main.js里安装全局事件总线: n...
    99+
    2024-04-02
  • vue中手动封装iconfont组件解析(三种引用方式的封装和使用)
    目录准备封装unicode引用封装font-class引用封装symbol引用封装引入全局引入局部引入使用在线使用 有时候会因网络问题影响用户体验;直接放在 本地使用 ,如果过多使用...
    99+
    2024-04-02
  • vue tree封装一个可选的树组件方式
    目录组件实现的基本功能先看效果图组件实现的基本功能 1,根据后端返回的数据格式,传入组件动态的渲染出当前角色有哪些权限(新建,修改) 2,适配有2级和只有一级多选的数据 3,有全选(...
    99+
    2024-04-02
  • Vue组件的自定义事件和全局事件总线怎么使用
    这篇“Vue组件的自定义事件和全局事件总线怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue组件的自定义事件和全局...
    99+
    2023-07-05
  • Vue组件二次封装的一些实用技巧总结
    目录前言透传 Attribute透传 slot普通slot动态插槽名作用域插槽封装组件存在的问题组件实例属性和方法的调用总结前言 在开发Vue项目我们一般使用第三方UI组件库进行开发...
    99+
    2024-04-02
  • 浅谈vue中文件下载的几种方式及方法封装
    一、通过对后端发送post请求,使用blob下载文件 function downBlob(res, fileName = "导出报表", format = "xlsx") {   ...
    99+
    2023-01-13
    vue 文件下载
  • Vue封装通过API调用的组件的方法详解
    目录前言封装通过API调用的组件的设计思路封装组件的方式单例模式定义单例模式的优缺点1、优点2、缺点单例模式适用场景使用API调用组件的示例拓展:父子组件通信最后前言 在前端开发中,...
    99+
    2022-12-26
    前端vue封装api然后调用 vue api封装 vue中组件封装
  • Vue使用Swiper封装轮播图组件的方法详解
    目录Swiper为什么要封装组件开始封装1.下载安装Swiper2.引入css样式文件3.引入js文件4.把官网使用方法中的HTML结构复制粘贴过来5.初始化Swiper自定义效果完...
    99+
    2024-04-02
  • WPF中鼠标/键盘/拖拽事件及用行为封装事件的方法是什么
    这篇“WPF中鼠标/键盘/拖拽事件及用行为封装事件的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“WPF中鼠标/键...
    99+
    2023-07-05
  • 插件化机制优雅封装你的hook请求使用方式
    目录引言useRequest 简介架构useRequest 入口处理Fetch 和 Pluginsstate 以及 setState插件化机制的实现核心方法 —&mdas...
    99+
    2024-04-02
  • vue中输入框事件的使用及数值校验方式
    目录vue输入框事件使用及数值校验一、@input(或者是v-on:input)二、@change三、@keyup.enter四、@blur(失焦)提示和注释vue中常用表单校验规则...
    99+
    2022-11-13
    vue校验 vue输入框事件 vue数值校验
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作