首页 文章

在历史模式下从子路径刷新时,组件安装两次

提问于
浏览
3

我在历史模式下使用vue-router . 当我在子路径"/dashboard"上并刷新页面时, <ccp/> 组件被挂载两次 . 在ccp组件中,我是控制台登录创建和挂载的挂钩 . 我看到每个控制台输出两次 . 有什么想法吗?在此先感谢您的期待!

编辑:在初始应用程序加载时,创建 <ccp/> 并仅挂载一次 .

这是代码:

App.vue:

<template>
    <div v-show="isConnected">
      <ccp/>
      <router-view/>
    </div>
</template>

<script>
     // blah blah blah - doing stuff and then pushing route to /dashboard
    return this.$router.push({name: "dashboard"});
</script>

router.js

export default new Router({
mode: "history",
routes: [
// DEFAULT ROUTE
{
  path: "/",
  name: "root",
  alias: store.getters.isDemoMode ? "/demo" : "/app" // isDemoMode is false for this test however I wanted to show the alias config in case that is part of the problem.
},

{
  path: "/demo",
  name: "demo",
  component: Demo
},
{
  path: "/app",
  name: "app",
  component: App,
  children: [
    {
      path: "/dashboard",
      name: "dashboard",
      component: Dashboard
    }
  ]
 }
})

1 回答

  • 1

    由于App组件也是您路线的一部分,因此可能会安装两次 . 名为 "app" 的路由正在重新安装App .

相关问题