8

我在我的项目中使用 vue-router。

我能够很好地导航到我的命名路线。我唯一的问题是,当我使用需要参数的命名路由时,刷新页面时它不会加载。

这是我的路线:

'/example/:username': {
    name: 'example-profile',
    title: 'Example Profile',
    component: ExampleComponent
}

这就是我使用的方式vue-router route

<a v-link="{ name: 'example-profile', params: { username: raaaaf } }">
    Example Link
</a>

当我选择Example Link我得到mydomain.com/example/raaaaf.

在第一次加载时,它会呈现正确的模板,但是当我刷新或手动输入地址栏上的链接时,我会被重定向到我Page Not Found的页面,并且不会触发创建页面时调用的方法。

这就是我的ExampleComponent

    <template>
    <div class="small-12 left">
        <side-bar></side-bar>
        <div class="store-right">
            <store-details></store-details>
            <store-menu></store-menu>
            <store-listings></store-listings>
        </div>
    </div>
    </template>
    
    <script>
        export default {
            data() {
                return {
                    username: null,
                    user: null,
                }
            },
    
            created() {
                this.getUser()
            },
    
            methods: {
                getUser() {
                    console.log(this.$route.params);
                }
            }
        }
    </script>
4

2 回答 2

8

我不知道是否有其他人遇到同样的问题,但我在刷新路由参数时遇到了问题。我试图获取的路由参数是一个 ID 号,我使用该 ID 来获取数据并填充页面。当我刷新时,我发现(通过许多控制台日志),数字变成了一个字符串,这就是页面无法正常工作的原因。我对其进行了整理,但在使用之前将 ID 转换为数字:

Number($route.params.id)
于 2017-10-23T12:41:34.543 回答
6

您需要正确配置服务器。您的服务器本质上是在目录中寻找索引文件/example/raaaaf。我会仔细阅读此页面:http ://router.vuejs.org/en/essentials/history-mode.html

于 2016-10-10T02:48:17.303 回答