[前端] Vue中一个组件调用其他组件的方法详解(非父子组件)

2488 0
Honkers 2022-11-8 19:45:09 | 显示全部楼层 |阅读模式
目录

    前言方式一:引用式方式二:vuex
      1、src/store/index.js2、被使用组件- A 页面(组件)3、使用触发页面-B 页面(组件)
    方式三:使用事件总线eventBus定义全局事件
      1、src/main.js2、触发页面-B组件/发布事件3、接收页面-A组件/订阅事件4、移除事件
    总结


前言

Vue中,一个组件调用其他组件的方法(非父子组件)
场景——B页面(组件)想调用 A页面(组件)中的方法;但是两个页面(组件)毫无关联(刷新 A的数据)。

方式一:引用式

1、当前组件引入将要调用方法所属的组件
这里我的当前组件要调用OrderDetail这个组件的check()方法
import Detail from "./detail.vue";
该方法定义在OrderDetail的methods属性中
2、当前组件通过该组件methods属性直接调用该方法
// 也可以调用 created、data等
Detail.methods.check();

方式二:vuex

使用 VueX 定义一个属性 ,然后在A页面 定义一个计算属性(computed) 再把 vuex 的属性返回给它,再监听这个计算属性,发生变化就调用你要执行的方法。

1、src/store/index.js

//  Vuex   全局
state: {
        tableStatus:false  
                 }
mutations:{  
        changeStatus(state,status) {  //  重复赋值
      state.tableStatus = status;
    },
}

2、被使用组件- A 页面(组件)

//  A 页面(组件)
computed: {  
  status() {  //  计算属性
    return this.$store.state.tableStatus; //  Vuex 中定义的属性
  }
},
watch:{
  status() {
    this.getTableList();  //   需要调用的方法
  }
},

3、使用触发页面-B 页面(组件)

然后就是在B 页面定义一个点击事件(举例),重新给 Vuex中的属性赋值就行了
//  B页面(组件)
closePage() {
    let status = this.$store.state.tableStatus;   // 重新赋值
    this.$store.commit("changeStatus", !status);
},

方式三:使用事件总线eventBus定义全局事件


1、src/main.js

window.eventBus = new Vue();

2、触发页面-B组件/发布事件

window.eventBus.$emit('setFeaturesData', data)  // 带参数
window.eventBus.$emit('setFeaturesData')  // 不带参数

3、接收页面-A组件/订阅事件

    window.eventBus.$on('setFeaturesData', (data)=>{ // 带参数
      this.hoveredFeatures = [data]
      this.onClick()
    })

  mounted() {
    this.getTableData()
    window.eventBus.$on('setFeaturesData', ()=>{ // 不带参数
      this.getTableData()
    })
  },

4、移除事件

window.eventBus.$off('setFeaturesData')
总结

到此这篇关于Vue中一个组件调用其他组件(非父子组件)的文章就介绍到这了,更多相关Vue组件调用其他组件内容请搜索中国红客联盟以前的文章或继续浏览下面的相关文章希望大家以后多多支持中国红客联盟!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Honkers

荣誉红客

关注
  • 4004
    主题
  • 36
    粉丝
  • 0
    关注
这家伙很懒,什么都没留下!

中国红客联盟公众号

联系站长QQ:5520533

admin@chnhonker.com
Copyright © 2001-2025 Discuz Team. Powered by Discuz! X3.5 ( 粤ICP备13060014号 )|天天打卡 本站已运行