开发者问题收集

如何以编程方式返回 Vue cli 预制的 Home.vue

2018-12-04
67

我正在使用 Vue CLI 3,它创建了一些路由。一个是 Home.vue。在我的程序中,我试图以编程方式转到不同的页面。我在 router.js 中添加了所需的路由,但保留了已经为 Home.vue 和 About.vue 创建的路由。它工作正常,直到我到达“Home”并收到警告:“[vue-router] 名为“Home”的路由不存在。”

这是代码:

 <template>
    <div class='secondItem'>
         <h4 v-for="item in menuItems" 
    @click="bindMe(item)" v-bind:class="{'active':(item === current)}">{{item}}</h4>
    </div>
    </template>
    <script>
    export default {
            name: 'Header',
            data() {
                return {
                    current: '',
                    menuItems: ['Home', 'About', 'Portfolio', 'Contact'],
                }
            },
            methods: {
                bindMe(item) {
                    this.current = item;
                    this.$router.push({
                            path: item
                        })
                }

            }
        }
    <script>
1个回答

您是否使用 命名路线 ?在这种情况下,您需要使用 name 而不是 path

this.$router.push({
  name: item
})

此外,您的示例可以简化很多。试试这个:

<template>
  <div class="secondItem">
    <router-link :to="{ name: item }" tag="h4" active-class="active" v-for="item in menuItems" v-bind:key="item">{{item}}</router-link>
  </div>
</template>

<script>
  export default {
    name: 'Header',
    data() {
      return {
        menuItems: ['Home', 'About', 'Portfolio', 'Contact']
      }
    }
  }
<script>
Kordonme
2018-12-04