最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

vuevuexvue-rouert权限路由(详细教程)

来源:动视网 责编:小采 时间:2020-11-27 19:37:02
文档

vuevuexvue-rouert权限路由(详细教程)

vuevuexvue-rouert权限路由(详细教程):这篇文章主要介绍了vue vuex vue-rouert后台项目——权限路由,通过本文可以很清除的捋清楚vue+vuex+vue-router的关系,本版本非常简单,适合初学者,需要的朋友可以参考下项目地址: vue-simple-template共三个角色:adan barbara carr
推荐度:
导读vuevuexvue-rouert权限路由(详细教程):这篇文章主要介绍了vue vuex vue-rouert后台项目——权限路由,通过本文可以很清除的捋清楚vue+vuex+vue-router的关系,本版本非常简单,适合初学者,需要的朋友可以参考下项目地址: vue-simple-template共三个角色:adan barbara carr
 这篇文章主要介绍了vue vuex vue-rouert后台项目——权限路由,通过本文可以很清除的捋清楚vue+vuex+vue-router的关系,本版本非常简单,适合初学者,需要的朋友可以参考下

项目地址: vue-simple-template

共三个角色:adan barbara carrie 密码全是:123456

adan 拥有 最高权限A 他可以看到 red , yellow 和 blue 页面(共三个页面)

barbara 拥有 权限B 他可以看到 red 和 yellow 页面

carrie 拥有 权限C 他可以看到 red 和 blue 页面

技术栈

webpack ---- 打包神器
vue ---- JavaScript 框架
vuex ---- 实现不同组件间的状态共享
vue-router ---- 页面路由
babel-polyfill ---- 将ES6代码转为ES5代码
normalize.css ---- 重置掉该重置的样式
element-ui ---- UI组件库

项目初始化

# cd 到项目文件夹
cd weven-simple-template
# 安装依赖 (本项目还安装了其他依赖详情 请见 package.json 文件)
npm install
# 运行项目
npm run dev

项目结构

vue-cil 脚手架初始化项目后,我只修改过src文件夹

src
├── App.vue ---- 页面入口
├── api ---- api请求
│ └── login.js ---- 模拟json对象数据
├── assets ---- 主题 字体等静态资源
│ └── logo.png
├── components ---- 组件
│ ├── index.vue
│ └── login.vue 
├── main.js ---- 初始化组件 加载路由
├── router ---- 路由
│ └── index.js
└── store ---- vuex状态管理
 ├── getters.js
 ├── index.js
 └── modules
 └── login.js

重点:

动态路由的关键在于router配置的 meta字段 和vuex的 状态共存 (不懂可以先查看官方文档)

router/index.js

// 初始化路由
export default new Router({ 
 routes: [
 {
 path: '/login',
 name: 'Login',
 component: Login
 }
 ] 
});
// 动态路由 meta 定义了role
export const powerRouter =[ 
 { path: '/',redirect:'/red', name: 'index',component: Index,hidden:false,
 children: [
 { path: '/red', name: 'red', component: red,},
 { path: '/yellow', name: 'yellow', component: yellow, meta: {role: 'B'}},
 { path: '/blue', name: 'blue', component: blue, meta: {role: 'C'}}
 ]
 }
];

store/modules/lo

Logins({ commit }, info){
 return new Promise((resolve, reject) => {
 let data={};
 loginByUserInfo.map(function (item) { //获取所以用户信息
 if(info.username === item.username || info.pew === item.pew){
 commit('SET_USERNAME',item.username); //将username和role进行存储
 sessionStorage.setItem('USERNAME', item.username); //存入 session 
 commit('SET_ROLE',item.role);
 sessionStorage.setItem('ROLE', item.role);
 return data={username:item.username,introduce:item.introduce};
 }else{
 return data;
 }
 }); 
 resolve(data);
 }).catch(error => {
 reject(error);
 });
 },
 Roles({ commit }, newrouter){
 return new Promise((resolve, reject) => {
 commit('SET_NEWROUER',newrouter); //存储最新路由
 resolve(newrouter);
 }).catch(error => {
 reject(error);
 });
 },

gin.js actions部分

Logins({ commit }, info){
 return new Promise((resolve, reject) => {
 let data={};
 loginByUserInfo.map(function (item) { //获取所以用户信息
 if(info.username === item.username || info.pew === item.pew){
 commit('SET_USERNAME',item.username); //将username和role进行存储
 sessionStorage.setItem('USERNAME', item.username); //存入 session 
 commit('SET_ROLE',item.role);
 sessionStorage.setItem('ROLE', item.role);
 return data={username:item.username,introduce:item.introduce};
 }else{
 return data;
 }
 }); 
 resolve(data);
 }).catch(error => {
 reject(error);
 });
 },
 Roles({ commit }, newrouter){
 return new Promise((resolve, reject) => {
 commit('SET_NEWROUER',newrouter); //存储最新路由
 resolve(newrouter);
 }).catch(error => {
 reject(error);
 });
 },

main.js

router.beforeEach((to, from, next) => {
 if(store.getters.role){ //判断role 是否存在
 
 if(store.getters.newrouter.length !== 0){ 
 next() //resolve 钩子
 }else{
 let newrouter
 if (store.getters.role == 'A') { //判断权限
 newrouter = powerRouter
 } else {
 let newchildren = powerRouter[0].children.filter(route => {
 if(route.meta){
 if(route.meta.role == store.getters.role){
 return true
 }
 return false
 }else{
 return true
 }
 });
 newrouter = powerRouter
 newrouter[0].children = newchildren
 }
 router.addRoutes(newrouter) //添加动态路由
 store.dispatch('Roles',newrouter).then(res => { 
 next({ ...to })
 }).catch(() => { 

 })
 } 
 }else{
 if (['/login'].indexOf(to.path) !== -1) { 
 next()
 } else {
 next('/login')
 }
 }
})

components/index.vue

// mapGetters 辅助函数仅仅是将 store 中的 getter 映射到局部计算属性
...mapGetters([
 'newrouter'
 ])

此项目拿去 捋清楚 vue+vuex+vue-router 的关系是没问题的,这可以说的超级简单的版本,适合初学。上面的内容说的重点,其实也算是项目的全部啦

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在js中如何实现上传并压缩图片功能(详细教程)

使用JS如何计算两个时间相差数

在vue-cli webpack中如何引入jquery(详细教程)

在vue中有关文件使用方式

纯js如何生成下拉列表

文档

vuevuexvue-rouert权限路由(详细教程)

vuevuexvue-rouert权限路由(详细教程):这篇文章主要介绍了vue vuex vue-rouert后台项目——权限路由,通过本文可以很清除的捋清楚vue+vuex+vue-router的关系,本版本非常简单,适合初学者,需要的朋友可以参考下项目地址: vue-simple-template共三个角色:adan barbara carr
推荐度:
标签: VUE 权限 教程
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top