Vue事件车,非父子组件通讯$bus,$event,中央事件总线

简介: Vue事件车,非父子组件通讯$bus,$event,中央事件总线

一般项目不大就利用事件车,公共的Vue实例进行传递数据

一共有两种写事件车的方式,下面一一介绍

  •   利用$emit发射自定义事件和 $on监听自定义事件
  •   $off销毁事件

一、第一种方式 (创建公共文件)

src文件夹下建立公共文件

// 建立公共的js文件(事件车),主要用来传递信息
// 引入vue.js
import Vue from 'vue';
// 创建空的vue实例
var event = new Vue();
export default event;

home.vue文件

<template>
  <div id="home">
    <h2>这是首页</h2>
    <h3>{{list}}</h3>
    <h5>{{mymsg}}</h5>
    <button @click="biu">发射</button>
  </div>
</template>
<script>
// 在需要传递信息的地方引入
import bus from '../eventBus.js'
export default{
  data(){
    return{
      list:['少欲音','正太音','大叔音'],
      mymsg:''
    }
  },
  methods: {
    biu(){
      // 发射一个自定义事件,用来传递信息
      console.log(bus);
      bus.$emit('biulist',this.list)
    }
  },
  mounted() {// 组件挂载时触发的钩子函数
    // 接收信息
    bus.$on('msg',val =>{
      this.mymsg = val
    })
  },
}
</script>

prodct.vue与首页毫无关联的页面


1.<template>
  <div id="product">
    <h2>这是商品页</h2>
    <ul v-for="val in item">
      <li>{{val}}</li>
    </ul>
    <button @click="fn">点击发射</button>
  </div>
</template>
<script>
// 在需要传递数据的地方引入
import bus from '../eventBus.js'
export default{
  data() {
    return {
       item:null
    }
  },
  methods: {
    fn(){
       bus.$emit('msg','这是商品页传来的数据')
    }
  },
  mounted() {
    // 接收信息
    bus.$on('biulist',val =>{
      this.item = val
    })
  },
}
</script>

二、第二种方式直接挂载到原型

在main.js中定义一个新的对象并挂载到vue原型上

Vue.prototype.$bus=new Vue();

home页

 methods: {
    msg() {
      //$emit发送数据携带数据
      this.$bus.$emit("A", {
        name: "张三",
        age: 20
      });
    }
}


prodct.vue与首页毫无关联的页面

1.mounted() {
//$on监听接收数据,这里注意一般写在mounted,计算属性里
    this.$bus.$on("A", function(res) {
      console.log(res);
    });
  }

两种方式任选其一哦!小编公_号❤前端老实人,可以一起聊天交流学习哦!

相关文章
|
1月前
|
JavaScript 前端开发 开发者
Vue的事件处理机制提供了灵活且强大的方式来响应用户的操作和组件间的通信
【5月更文挑战第16天】Vue事件处理包括v-on(@)指令用于绑定事件监听器,如示例中的按钮点击事件。事件修饰符如.stop和.prevent简化逻辑,如阻止表单默认提交。自定义事件允许组件间通信,子组件通过$emit触发事件,父组件用v-on监听并响应。理解这些机制有助于掌握Vue应用的事件控制。
36 4
|
7天前
|
JavaScript
Vue.js中使用.self修饰符来限制事件处理程序的作用域
Vue.js中使用.self修饰符来限制事件处理程序的作用域
|
2天前
|
JSON 移动开发 JavaScript
Vue03基础语法(样式绑定、事件处理器、表单、自定义指令、vue组件、组件通信【自定义事件】)
Vue03基础语法(样式绑定、事件处理器、表单、自定义指令、vue组件、组件通信【自定义事件】)
9 0
|
1月前
|
缓存 JavaScript
Vue: 事件修饰符, 键盘事件, 鼠标事件,计算属性
Vue: 事件修饰符, 键盘事件, 鼠标事件,计算属性
34 2
|
1月前
|
JavaScript 编译器
Vue3之事件
Vue3之事件
26 0
|
1月前
|
XML 移动开发 前端开发
ruoyi-nbcio-plus基于vue3的flowable定时捕获事件代码升级修改
ruoyi-nbcio-plus基于vue3的flowable定时捕获事件代码升级修改
72 0
|
1月前
|
移动开发 前端开发
ruoyi-nbcio-plus基于vue3的flowable定时边界事件代码升级修改(三)
ruoyi-nbcio-plus基于vue3的flowable定时边界事件代码升级修改(三)
18 0
|
1月前
|
JavaScript
Vue3的 组件事件
Vue3的 组件事件
27 0
|
1月前
|
JavaScript 前端开发 开发者
事件处理:深入理解Vue的事件机制
【4月更文挑战第23天】Vue.js的事件处理机制是其核心特性之一,允许开发者响应用户操作。通过`v-on`(或简写`@`)指令绑定DOM事件到方法,当事件触发时执行相应代码。事件修饰符如`.stop`、`.prevent`等简化了常见逻辑。此外,Vue支持自定义事件,便于组件间通信,如子组件通过`$emit`触发事件,父组件使用`v-on`监听并处理。理解这些概念能帮助开发者更有效地控制Vue应用的事件流程。
|
1月前
|
JavaScript
vue 组件事件
vue 组件事件