vue路由:
1:动态路由配置
import Vue from 'vue'
import Router from 'vue-router'
import Index from '@/view/index'
import Layout from '@/view/layout'
import Home from '@/view/home'
import error from '@/view/error'
import p404 from '@/view/404'
import p505 from '@/view/505'
import Login from '@/login'
import AddGood from '@/view/table/addGoods'
Vue.use(Router)
const router = new Router({
routes: [
{path:'/',redirect:'/home'},
{
path: '/',
name: 'Index',
component: Index,
children:[
{
path: 'home',
name: 'Home',
component: Home,
meta:{
requireLogin:true
},
},
{
path: 'add',
name: 'AddGood',
component: AddGood,
meta:{
requireLogin:true
},
}
]
},
{
path: '/login',
name: 'Login',
component: Login
},
{
path: '/error',
name: 'error',
component: error,
children:[
{
path: '404',
name: '404',
component: p404,
},
{
path: '505',
name: '505',
component: p505,
}
]
}
]
})
// 路由拦截
router.beforeEach((to, from, next) => {
if (to.matched.some(res => res.meta.requireLogin)) {
// 判断是否需要登录权限
if (window.localStorage.getItem("username")) {
next();
} else {
// 没登录则跳转到登录界面
console.log("to login");
next({
path: "/login"
});
}
} else {
next();
}
});
export default router;
2:响应路由参数的变化:
例如从/user/foo导航到/user/bar,原来的组件会被复用,
这种方式获取url上的参数可以watch来监视$route对象来获取
3:嵌套路由:要在嵌套的出口中渲染组件,需要在 VueRouter
的参数中使用 children
配置:
const router = new VueRouter({
routes: [
{ path: '/user/:id', component: User,
children: [
{
// 当 /user/:id/profile 匹配成功,
// UserProfile 会被渲染在 User 的 <router-view> 中
path: 'profile',
component: UserProfile
},
{
// 当 /user/:id/posts 匹配成功
// UserPosts 会被渲染在 User 的 <router-view> 中
path: 'posts',
component: UserPosts
}
]
}
]
})
路由可以层层嵌套;要注意,以 / 开头的嵌套路径会被当作根路径。 这让你充分的使用嵌套组件而无须设置嵌套的路径。
当你访问一个没有匹配的路由的时候,如果要渲染点什么东西,可以提供一个空的子路由
const router = new VueRouter({
routes: [
{
path: '/user/:id', component: User,
children: [
// 当 /user/:id 匹配成功,
// UserHome 会被渲染在 User 的 <router-view> 中
{ path: '', component: UserHome },
// ...其他子路由
]
}
]
})
### 4:编程式导航:router.push(location, onComplete?, onAbort?)
除了使用 <router-link> 创建 a 标签来定义导航链接,我们还可以借助 router 的实例方法,通过编写代码来实现。
注意:在 Vue 实例内部,你可以通过 $router 访问路由实例。因此你可以调用 this.$router.push
想要导航到不同的 URL,则使用 router.push 方法。这个方法会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL。
当你点击 <router-link> 时,这个方法会在内部调用,所以说,点击 <router-link :to="..."> 等同于调用 router.push(...)。
该方法的参数可以是一个字符串路径,或者一个描述地址的对象。例如
// 字符串:router.push('home')
// 对象:router.push({ path: 'home' })
// 命名的路由:router.push({ name: 'user', params: { userId: '123' }})
这里的命名是指在route.JS里面定义动态路由配置name,参考第一点
带查询参数:变成 /register?plan=private
router.push({ path: 'register', query: { plan: 'private' }})
注意:如果提供了path,则params会被忽略,因此不能这样写:
this.$router.push({ path: 'register', params: { plan: 'private' }})这样是不能解析参数出来的。
正确的写法应该是这样:
this.$router.push({path:`user/${userID}`}) ===> /user/123,
this.router.push({path:'user',params:{userID}}) ====> /user,不能解析出userID
注意跟命名路由的区别:
this.$router.push({name:'user',params:{userId: 123}})===> /user/123
用于记住导航链接:在 2.2.0+,可选的在 router.push
或 router.replace
中提供 onComplete
和 onAbort
回调作为第二个和第三个参数。这些回调将会在导航成功完成 (在所有的异步钩子被解析之后) 或终止 (导航到相同的路由、或在当前导航完成之前导航到另一个不同的路由) 的时候进行相应的调用。
注意: 如果目的地和当前路由相同,只有参数发生了改变 (比如从一个用户资料到