V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
matts8023
V2EX  ›  前端开发

如何通过 vue 实例访问 vue 路由当前显示的单页里的方法?

  •  
  •   matts8023 · 2017-07-11 16:34:12 +08:00 · 2451 次点击
    这是一个创建于 2474 天前的主题,其中的信息可能已经有所发展或是发生改变。

    由于项目需要,用了 SPA 方式进行开发,使用的是 webpack + vue-loader + vue + vue-router。概要代码如下:

    // main.vue
    <template>
      <router-view ref="routerInstance"></router-view>
    </template>
    
    
    // index.vue
    <template>
      <h>Index!!!</h>
    </template>
    <script>
    export default {
      methods: {
        callFromOutside() {
           alert()
        }
      }
    }
    </script>
    
    
    // router.js
    module.exports = {
      routes: [{
        name: 'Index',
        path: '/',
        component: require('./index.vue')
      }]
    }
    

    如果想从 vue 实例对象访问 index.vue 里的 callFromOutside,假设是 vue 实例变量为 vm,同时当前路由页是 Index,则直接调用:

    vm.$refs.routerInstance.callFromOutside()
    

    会提示 undefined。请问这里是哪里出问题了?

    1 条回复    2017-07-12 07:13:23 +08:00
    klausgao
        1
    klausgao  
       2017-07-12 07:13:23 +08:00 via iPhone
    公共方法就直接封装进一个 base.js 啊,然后 import 进来就可以用了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2911 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 75ms · UTC 02:51 · PVG 10:51 · LAX 19:51 · JFK 22:51
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.