Vue学习笔记(十):全局事件总线

之前博客中介绍了prop和调用事件的方式在父-子组件之间进行数据,这种方式在只有一层嵌套层时可以使用,但是路过存在多层嵌套,多层多个"兄弟"组件之间传递数据,就非常麻烦。对此,vue中提供了一种全局事件总线机制,数据传递是通过一个空的Vue实例作为中央事件总线,通过它来触发事件和监听事件,可以实现几乎任何组件间的通信,这在一些比较小的项目中是非常好用的。
全局事件总线相当于一个公共空间,任何组件都可以将事件绑定到其中,任何其他组件都可以去出发绑定到这个公共空间的方法,实现组件之间的数据交互。
使用全局事件总线之前,需要在main.js中进行安装:

复制代码
//引入Vue
import Vue from 'vue'
//引入App
import App from './App.vue'
//关闭Vue的生产提示
Vue.config.productionTip = false

//创建vm
new Vue({
    el:'#app',
    render: h => h(App),
    beforeCreate() {
    	Vue.prototype.$bus = this //安装全局事件总线
    },
})

组件将事件绑定到全局事件总线中:

复制代码
<template>
    <div class="demo2">
        <hello1 
        v-for="per in persons"
        :key="per.id"
        :perObj=per
        >
        </hello1>
    </div>
</template>

<script>
import hello1 from './hello1.vue'
    export default {
        name: 'hello2',
        data(){
            return {
                persons: [
                    { id: 1, name: '张三', age: 23 },
                    { id: 2, name: '李四', age: 34 },
                    { id: 3, name: '王五', age: 45 }
                ]
            }
        },
        components:{
            hello1
        },
        mounted() {
            this.$bus.$on('changeAge1', (id)=>{   // 将事件changeAge1添加到事件总线中
                this.persons.forEach((per)=>{
                    if(per.id === id) per.age += 1
                });
                console.log('id值为:', id, 'age值加1')
            })
        }
    }
</script>

其他组件触发事件总线中的事件,实现数据交互:

复制代码
<template>
    <div class="demo1">
        <h4>{{perObj.name}} 的年龄是:{{perObj.age}}</h4>
        <!-- 此处调用从父组件中传过来的函数 -->
        <button @click="changeAge2(perObj.id)">修改年龄</button>
    </div>
</template>

<script>
    export default {
        name: 'hello1',
        props:['perObj'],
        methods: {
            changeAge2(id){
                this.$bus.$emit('changeAge1', id)
            }
        },
    }
</script>
相关推荐
研來如此7 分钟前
C++ 接口设计 && Doxygen 注释
前端·javascript·c++
野槐1 小时前
Electron开发
前端·javascript·electron
#做一个清醒的人1 小时前
【Electron】开发两年Electron项目评估报告
前端·electron
lizhongxuan7 小时前
Claude Code 防上下文爆炸:源码级深度解析
前端·后端
柳杉9 小时前
震惊!字符串还能这么玩!
前端·javascript
是上好佳佳佳呀9 小时前
【前端(五)】CSS 知识梳理:浮动与定位
前端·css
wefly201710 小时前
纯前端架构深度解析:jsontop.cn,JSON 格式化与全栈开发效率平台
java·前端·python·架构·正则表达式·json·php
我命由我1234511 小时前
React - 类组件 setState 的 2 种写法、LazyLoad、useState
前端·javascript·react.js·html·ecmascript·html5·js
自由生长202412 小时前
IndexedDB的观察
前端
IT_陈寒12 小时前
Vite热更新坑了我三天,原来配置要这么写
前端·人工智能·后端