我有多个项目块,类似于下面的jsfiddle中的书。每本书都有一个子菜单,用户可以单击以查看特定的书籍内容。

问题是当用户访问book1/summary时,所有其他书籍也将切换到Summary Component。我不想那样,我希望所有其他书籍独立地呆在原处。例如:book1显示摘要,book2显示条件,book3显示预订,并且每个预订彼此独立。

有人可以帮忙吗?非常感谢。

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'
    }
  })

最佳答案

您应该能够使用 CHILD ROUTES 使它正常工作,但是您需要稍微更改一下设置。

每本书里面都需要单独的导航,里面需要<router-view>,然后在特定书内调用子路线应该起作用。

尝试引用文档:https://router.vuejs.org/en/essentials/nested-routes.html

关于navigation - Vue Router多个独立的路由器 View 导航,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42705739/

10-12 00:08
查看更多