广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue中一个组件调用其他组件的方法详解(非父子组件)
  • 240
分享到

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

vue调用其他组件方法vue组件调用vue组件之间调用 2022-11-13 18:11:35 240人浏览 薄情痞子
摘要

目录前言方式一:引用式方式二:Vuex1、src/store/index.js2、被使用组件- A 页面(组件)3、使用触发页面-B 页面(组件)方式三:使用事件总线eventBus

前言

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组件调用其他组件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Vue中一个组件调用其他组件的方法详解(非父子组件)

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

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

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

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

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作