当我在登录页面和仪表板之间拆分视图时,我有问题,这是我的代码
MainApp.vue
<template>
<div class="main-wrapper">
<div class="navbar-bg"></div>
<TopNav />
<SideBar />
<div class="main-content">
<router-view></router-view>
</div>
<Footer />
</div>
</template>
<script>
import TopNav from "./partials/TopNav";
import SideBar from "./partials/SideBar";
import Footer from "./partials/Footer";
export default {
name: "MainApp",
components: {
TopNav,
SideBar,
Footer
}
};
</script>
路由器.js
import Vue from 'vue';
import VueRouter from 'vue-router';
import Dashboard from '../components/Dashboard';
import Post from '../components/Post';
import Login from '../view/Login';
Vue.use(VueRouter);
const router = new VueRouter({
mode: 'history',
routes: [
{
title: 'Login Page',
path: '/back/login',
name: 'login',
component : Login
},
{
title: 'Dashboard',
path: '/',
name: 'dashboard',
component: Dashboard
},
{
path: '/post',
name: 'post',
component: Post
},
]
});
export default router;
应用.js
import Vue from 'vue';
import Vuex from 'vuex';
import Router from './router'
import MainApp from './layouts/MainApp.vue'
Vue.use(Vuex);
new Vue({
router: Router,
render: h => h(MainApp)
}).$mount('#app');
从上面的这些代码中,每次我转到“/返回/登录”路由时,登录页面始终显示仪表板(侧边栏,topnav和页脚)组件,是的,我知道为什么会发生这种情况,因为它总是呈现MainApp.vue。由于这是我第一次使用vuejs制作SPA应用程序,我仍然不知道这样做的最佳方法是什么(如果不是SPA,那么解决这个问题会很容易),所以我在这里尝试了一些愚蠢的东西,我添加了一些这样的条件
new Vue({
router: Router,
render: $route.name ? !== 'login' ? h => h(MainApp) : h => h(login)
}).$mount('#app');
它给了我错误“这个$route没有定义”,我猜它只在组件内部工作,对吧?
所以我想问在登录页面和仪表板页面之间拆分视图的最佳方法
呼啦一阵风
相关分类