vue实现a组件中数据变化b组件实时更新(ab组件无关联)

需求:A组件新增、编辑或者删除数据时,B组件实时更新数据                

// src/utils/bus.js

// bus.$emit('bridge-updated') 是在事件总线实例 bus 上触发了一个自定义事件
// 'data-updated',相当于发布了一个事件。

// bus.$on('bridge-updated',()=>{}) 则是在事件总线实例 bus 上监听了自定义事件
// 'data-updated',一旦该事件被触发,就会执行对应的回调函数。

// 也就是说,通过 bus.$emit 方法,a组件可以在数据更新之后主动发出一个事件;
// 而在b组件中使用 bus.$on 方法,监听了该事件,并在事件触发时执行相应的操作,
// 这就实现了 a组件更新数据时,b组件无感知地重载 的效果。

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



// main.js

import bus from "@/utils/bus";
// 全局方法挂载
Vue.prototype.bus = bus;
// 组件A

// 在更新数据后,派发自定义事件 bridge-updated

    submitForm() {
      if (this.title === "新增") {
        infoInsert(this.formData).then((res) => {
          if (res.code === 1) {
            this.$message.success("新增成功");
            this.hideDialog();
          }
        });
      } else if (this.title === "修改") {
        infoUpdate(this.formData).then((res) => {
          if (res.code === 1) {
            this.$message.success("修改成功");
            this.hideDialog();
          }
        });
      }
    },


    hideDialog() {
      this.dialogVisible = false;
      this.isDisable = false;
      this.mapData = {
        open: false,
        disabled: false,
      };
      this.$refs.form.resetFields();
      this.$parent.getTableData();
      this.echoImgList = [];
      this.bus.$emit('bridge-updated') // 重点是这个 
    },
// 组件B
// 监听data-updated事件,更新数据并重载

   created() {
      this.bus.$on('bridge-updated', () => {
        this.getBridgeList()
      })
    },


    // 更新数据
    getBridgeList() {
        infoQueryList().then(res => {
          if (res.code === 1) {
            this.bridgeList = res.data
          }
        })
      }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值