欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue中实现在外部调用methods的方法(推荐)

程序员文章站 2022-04-18 22:12:16
1.首先定义一个公共的vue组件; var eventhub = new vue(); 2.在事件当前的组件中,在created中,用$on向公共的组件e...

1.首先定义一个公共的vue组件;

var eventhub = new vue(); 

2.在事件当前的组件中,在created中,用$on向公共的组件eventhub传递,translate是自定义的,getcardnum(data)是要在外部调用的方法;

eventhub.$on('translate', function (data) { 
        that.getcardnum(data); 
      }); 

3.最后在父组件中,注意负组件要用一个变量保存,var vm = new vue({});

4.在父组件中的methods的方法中定义一个方法,在方法里用$emit接收公共组件里的方法;

var vm = new vue({ 
 el: '#example', 
 data: { 
  msg: 'hello directive', 
  data: {} 
 }, 
 methods: { 
  getcardnum: function (data, on) { 
   eventhub.$emit('translate', data); 
  } 
 } 
}); 

5.最后就可以在vue组件外部,或者文件外部调用getcardnum(data)这个函数,比如在html中就可以 onclick = vm.getcardnum() 这样来调用;vm是父组件

6.注意一定要把父组件的变量名写上 vm.getcardnum();

我用vue开发的过程中,遇到java后台的弹窗页面想要调用我vue组件中的方法,可是后台的弹窗页面并没有在我的vue组件中,其他的页面想要调用的vue中的方法,只能在父组件中调用,于是研究了很久,最后确定,将组件中的function()方法传递到最上一层的父组件中,将负组件保存在变量中,最后直接在其他页面中调用方法,调用的时候,就不能用@click方法来调用了,因为后台的页面并不在我的vue组件内部,于是调用就是onclick = vm.getcardnum();这样调用,vm是父组件

以上这篇vue中实现在外部调用methods的方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。