<div> <ul class="tabBar"> <li v-for="(item,index) in tabList" :key="index"> <router-link :to="{path:item.url}">{{item.tit}}</router-link> </li> </ul> <router-view class="cont"></router-view> </div>
.tabBar { width: 100%; height: 90px; display: flex; border-bottom: 1px solid #ccc; } .tabBar li { display: flex; flex: 1; height: 90px; } .tabBar li a { width: 100%; line-height: 90px; display: block; text-align: center; } .router-link-active { color: red; /*background-color: #003399;*/ border-bottom: 1px solid red; } .cont { display: flex; justify-content: center; align-items: center; }
export default { data() { return { isShow: true, tabList: [ { url: '/a', tit: "One" }, { url: '/b', tit: "Two" }, { url: '/c', tit: "Three" } ] } } }
import Vue from 'vue' import Router from 'vue-router' Vue.use(Router); Router.prototype.animate = 0; const _import = file => () => import('@/views/' + file + '.vue'); const _import_ = file => () => import('@/components/' + file + '.vue'); /* * slide:页面切换动画 * login:是否需要登陆 * */ Vue.use(Router); export default new Router({ linkActiveClass: "router-link-active",//后代路由被激活时,给路由标签添加指定样式 routes: [ { path: '/', name: '首页', component: _import('home/index'), children: [ { path: '', redirect: '/a' },//访问首页的时候默认访问后代路由中的a { path: '/a', component: _import_('common/a') }, { path: '/b', component: _import_('common/b') }, { path: '/c', component: _import_('common/c') }] }, { path: "/list", name: "list", component: _import("home/list"), meta: { slide: 1, login: true } }, { path: "/search", name: "search", component: _import("search/index"), meta: { slide: 1 } }, { path: "/center", name: "center", component: _import("center/index"), meta: { slide: 1 } },] })