在实际项目中很多地方需要router的运用,下面从实践运用的例子总结一下需要引用router的地方
这里实现访问权限限制还需要访问vuex的store,获取当前用户的权限,判断是否允许跳转
{
path:'/CarsList',
name:'CarsList',
component:CarsList,
meta: { requiresAuth: true } //首先在要被限制的路由设置路由元信息,可以通过匹配requiresAuth(可修改)字段验证该路由是否拦截,现在设置了carList为未登录拦截组件(未登录不可访问)
},
//书写全局拦截守卫,router是声明的路由组件
router.beforeEach((to, from, next) => {
if (to.matched.some(record => record.meta.requiresAuth)) { //第一个检测跳转的页面是否设置了未登录不可查看权限
// $store.state.checklogin
if (store.state.checklogin) { //如果跳转的是要登录权限的页面,这里就是通过访问store检测用户是否登录
//大坑,这里是通过访问vue中的store.js 的登录状态来检测权限,在这里访问store不能使用全局变量$store.state,因为这时候页面还没加载,所以要在路由头部import 引用store.js文件!!!!!!!
console.log('你还没登录呀!');
next({
name: 'GoodsSelect',
// query: { redirect: to.fullPath},//这里是实现路径重定义,方便完成登录动作直接跳转到本页面
params:{err:1} //放回是传递信息给主页面,方便交互(告诉用户不能访问该地方)
})
} else {
next()
}
} else {
next() // 确保一定要调用 next()
}
});
在权限不够是跳转到默认页面接收params并作出相应动作
mounted(){ //每次进入该页面挂载时即验证this.$route.params.err传来信息
if( this.$route.params.err){
this.$message({
type: 'warning',
message: '您还没登录呀,请登录!'
});
}
},
<transition name="el-fade-in-linear">
<router-view class="app-router-view">router-view>
transition>
//只需要在transiton加入相应的css属性就可以控制切换效果,router官网还提供每一个组件路由进出的切换效果,这里的效果每个组件都相同,"el-fade-in-linear"是element淡入淡出的继承样式,可以直接用
//如果要想在整个页面进出有动态效果直接在scss属性样式设置
<transition-group name="list-complete" tag="el-col" appear>
<el-col :span="span" v-for="(item,index) in data" :key="index" v-show="item.carshow&&item.carprice" class="list-complete-item">
<div class="item ">
<el-card :body-style="{ padding: '0px'}">
<img :src="item.car_photo_url" class="item-img" />
</el-card>
...
</div>
</div>
</el-col>
</transition-group>
//同样是用name标志样式来控制(注意如果不是单个的组件,一定要用transition-group)
如果上一个页面交互中数据与下一个页面有交互(
eg:租车网页首页选择了时间、地点,按确定跳转到汽车展示路由,并请求后台汽车数据,就是大概这么一个过程
)
A页面携带参数跳转到B页面 逻辑思路:
A触发绑定事件编程式:router.push(…),触发该事件将跳转到目标路由,并打包参数传到该路由组件,B组件每次挂载mounted时会检测是否有路由传输参数$route.params,有就加载参数执行后台请求动作,渲染页面,完成参数传输的全过程。
A页面代码
//触发该事件将,编程式路由会跳转和携带参数
postCarlist(site,stime){ //前面的两个if语句是检车输入数据是否合法,我自己项目的检测
if(site.length == 0||stime.length == 0){ //验证输入数据是否为空
this.$message({
type: 'warning',
message: '请输入完整时间、地点'
});
}else{
var today=new Date();
if(stime[0]//验证输入的时间是否正确(只能预定)
this.$message({
type: 'warning',
message: '请输入至少2个小时后的时间段'
});
}else{
// 重点是在这里,name后面跟的是要跳转路由的名字,(用name做标记而不用path的原因是path不能用params传输数据,params
后面带的就是要传输的数据si)
this.$router.push({ name: 'CarsList',params: { selectsite:this.si}});
}
}
},
B页面要接受数据并作出的相关动作
mounted(){ //每次挂载的时候都检查数据
let site=this.$route.params.selectsite; //这里是接受刚刚传递过来的数据
if(site.value.length>0){ //如果数据存在,即将参数传递给方法进行请求渲染
this.postCarlist(site.site,site.value)
}
},
const CarsList = () => import('@/views/CarsList')
//当路由引用组件Carslist时才加载Carlist,路由其他地方不需要改变,也不需要引入该组件
最后放一下最近租车网站设计的进度图(都是运用了上面的技术栈)
导航守卫的例子
ps:这时的拦截页面就很适合用懒加载啦
组件参数传输例子