web-dev-qa-db-ja.com

Vueルーター複数の独立したルーター-ナビゲーションを表示

以下のjsfiddleの本に似たアイテムのブロックが複数あります。各本にはサブメニューがあり、ユーザーはクリックして特定の本のコンテンツを表示できます。

問題は、ユーザーがbook1/summaryにアクセスすると、他のすべての本もSummaryComponentに切り替わるということです。私はそれを望んでいません、私は他のすべての本が独立して彼らがいる場所にとどまって欲しいです。例:book1はSummaryを表示し、book2はConditionを表示し、book3はReservationを表示し、それぞれが他から独立しています。

誰かが助けることができますか?どうもありがとう。

https://jsfiddle.net/trachanh/pL4rmua6/2/

<div id="app">
  <router-link to="/">/home</router-link>
  <router-link to="/foo">/foo</router-link>
  <router-link to="/books">/books</router-link>
  <router-view></router-view>
</div>

<template id="books">
 <div> 
  <div class="book" v-for="book in books">

  <h3>{{book.title}}</h3>
      <ul>
          <router-link :to="{ path: '/books/'+book.id+ '/summary'}">Summary</router-link>
          <router-link :to="{ path: '/books/'+book.id+ '/location'}">Location</router-link>
          <router-link :to="{ path: '/books/'+book.id+ '/condition'}">Condition</router-link>
          <router-link :to="{ path: '/books/'+book.id+ '/reservation'}">Reservation</router-link>
      </ul>    
      <router-view></router-view>
  </div>
 </div>
</template>


  const Home = { template: '<div>Home</div>' }
  const Foo = { template: '<div>Foo</div>' }

  const Books = {
    template: '#books',
    data: function(){
        return {
          books: [
            {id: 1, title: 'Harry Potter'},
            {id: 2, title: 'Twilight'},
            {id: 3, title: 'The Hobbit'}
          ]
        }
    }
  }

  const summary = { template: '<div>Summary component</div>' }
  const location = { template: '<div>Location component</div>' }
  const condition = { template: '<div>Condition component</div>' }
  const reservation = { template: '<div>Reservation component</div>' }

  const router = new VueRouter({
    mode: 'history',
    routes: [
      { path: '/', component: Home },
      { path: '/foo', component: Foo },
      { path: '/books', component: Books,
        children: [
                {
                  path: ':bookID/summary',
                  component: summary
                },
                {
                  path: ':bookID/location',
                  component: location
                },
                {
                  path: ':bookID/condition',
                  component: condition
                },
                {
                  path: ':bookID/reservation',
                  component: reservation
                }
          ]
    }]
  })

  new Vue({
    router,
    el: '#app',
    data: {
      msg: 'Hello World'
    }
  })
6
Nguyen Anh Vu

CHILD ROUTESを使用して動作させることができるはずですが、設定を少し変更する必要があります。

すべての本は内部で別々のナビゲーションを必要とし、<router-view>その中、そして特定の本の中の子ルートを呼び出すことはうまくいくはずです。

ドキュメントを参照してみてください: https://router.vuejs.org/en/essentials/nested-routes.html

3
M U