Having some trouble setting up Vue.js with the router, specifically dealing with view display issues. I've created a router.js
file with child routes for breadcrumbs and route clarity purposes.
Each individual route loads perfectly fine when opened. For example, when I navigate to /apps
, I see the expected view from my Apps.vue
component showcasing the message App overview
. However, the problem arises when I proceed to /apps/app-one
, both the Apps.vue
and AppOne.vue
templates are displayed. Is there a way to prevent this?
The structure of the Vue components is as follows:
Router.js
import Router from 'vue-router';
import AppsPage from './components/Apps.vue'
import AppOne from './components/AppOne.vue'
import AppTwo from './components/AppTwo.vue'
export default new Router({
// mode: 'history',
routes: [
{
path: '/apps',
component: AppsPage,
children: [
{
path: '/apps/app-one',
component: AppOne,
},
{
path: '/apps/app-two',
component: AppTwo,
},
]
},
]
});
Apps.vue
<template>
<div id="app-overview">
<h1>App overview</h1>
<router-view></router-view>
</div>
</template>
<script>
export default {
name: 'app_page'
}
</script>
App1.vue
<template>
<div>
<h1>App 1</h1>
</div>
</template>
<script>
export default {
name: 'app_one'
}
</script>
App2.vue
<template>
<div>
<h1>App 2</h1>
</div>
</template>
<script>
export default {
name: 'app_two'
}
</script>