49
42

More than 5 years have passed since last update.

Vue-routerで遷移時にパラメタを渡し方

Last updated at Posted at 2018-06-24

vue-routerで画面遷移時にパラメータ渡すのに手詰まったのでメモ

サンプルリポジトリ

https://github.com/Godan/tutorial-vue-router

サンプルのvue-routerのルーティング

pathにはパターンを書きます。:を先頭に書くのはrailsのroutesと同様ですね。

import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/',
      name: 'index-page',
      component: require('@/components/index').default
    },
    {
      path: '*',
      redirect: '/'
    },
    {
      path: 'fuga',
      name: 'fuga-view',
      component: require('@/components/fuga').default
    },
    {
      path: '/hoge/:value',
      name: 'hoge-view',
      component: require('@/components/hoge').default
    }
  ]
})

リンク元ページ

リンク元でrouter-linkタグを使ってリンクを張ります。toの中身はハッシュで渡していきます。

<template>
  <div id="wrapper">
        <router-link :to="{ name: 'hoge-view', params: { value: 'test value' }}" >hoge Link</router-link >
        <router-link :to="{ name: 'fuga-view' }" >fuga Link</router-link >
    </main>
  </div>
</template>

リンク先ページ

リンク先は通常変数と同様に展開します。

<template>
  <div>
    <router-link :to="{ name: 'index-page' }"> back </router-link>
    This is hoge page.   value is {{ $route.params.value }} 
  </div>
</template>

リンクが変更されたときに関数を呼び出す

変更に合わせて関数を呼び出す場合はvueに用意されているウォッチャーを使います

new Vue({
  components: { App },
  router,
  store,
  template: '<App/>',
  watch: {
    $route: function (to, from) {
      // ここにコードを書く
    }
  }
}).$mount('#app')

49
42
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
49
42