meta?
meta简单来说就是路由元信息 也就是每个路由身上携带的信息。
- 列举几个例子:
①.面包屑效果

路由信息:

页面:

②.可以在路由导航守卫跳转的时候判断有没有这个信息,如果有让跳转
如: 设置meta属性

设置路由守卫

③.根据不同的用户权限分配不同的路由导航
当我登录是,通过判断是管理员还是普通用户,引导他们进入不同的内容的index.vue组件页面。没错,只用一个页面,实现两种权限。

- 有多种方式 先来看下第①种:
可以提前创建几套路由规则 然后在需要切换的页面中进行引用

②.切换整套路由
- 首先要另外新创建一套路由,将所有的路由规则拷贝过去,只在这个一级路由的子路由那进行内容更改。

另一套路由:

- 然后在登录页面里面 通过判断后台返回的登录状态码(或根据导航守卫是否携带token) 分配不同的权限。

这样就能实现普通用户进入普通页面,超管进入超管页面了
总结了几个需要注意的事项:
①. 路由出口 <router-view></router-view> 放在哪,下级路由里的内容就显示在什么地方

②. 给属性绑定值时,一定记得加上"v-bind"或者" : "

③. 首次打开哪个二级路由,如果这个一级路由没有路由展示入口,可以直接在路由跳转时直接重定向到某个二级路由

使用:

④. addRouter可以动态改变路由
本文介绍了Vue.js中如何利用meta字段实现面包屑导航、路由守卫以及用户权限控制。通过设置不同路由的meta信息,可以实现在导航时动态展示内容,以及根据用户权限分配不同页面。在登录时,根据返回的状态码或token来决定用户进入的页面,从而实现普通用户和管理员的差异化体验。注意路由出口的位置、属性绑定以及首次加载时的重定向策略,动态添加路由也是关键操作之一。
&spm=1001.2101.3001.5002&articleId=117956944&d=1&t=3&u=797594bce68b4190a79a6d59e6156d0c)
4028

被折叠的 条评论
为什么被折叠?



