前端实现不同角色登入展示不同页面效果实例

 更新时间:2024年08月12日 09:09:03   作者:umumuuuyqs  
要实现不同角色登录跳转不同的前端页面,可以在登录成功后,根据用户的角色信息,使用路由跳转到不同的页面,这篇文章主要给大家介绍了关于前端实现不同角色登入展示不同页面效果的相关资料,需要的朋友可以参考下

功能介绍:首先是不同身份的用户展示的界面不同,其次实现在注册时选择对应的身份

不同身份的用户系统展示界面不同

1. 数据库user 表中添加role属性

No.1 点击“表”——右击“user”——点击“设计表”——添加“role”属性——user表中进行角色设置

添加属性:

No.2  “user”表中进行“role”多种角色设置(比如,用户,管理员)

2. 在后台的 User 类里面加一个新的字段叫 role,然后重启后台

3. 在菜单的标签上加一个 v-if 判断就可以了(eg:想让管理员看到这个菜单)

<!--          <el-submenu>二级菜单-->
<el-submenu index="info" v-if="user.role==='管理员'">
  <template slot="title">
    <i class="el-icon-house"></i>
    <span> 信息管理</span>
  </template>
  <el-menu-item index="/user">用户信息</el-menu-item>
</el-submenu>

完善:路由守卫解决用户页面权限问题 (添置index.js页面)

router.beforeEach((to, from, next) => {
  // to 是到达的路由信息
  // from 是开源的路由信息
  // next 是帮助我们跳转路由的函数
  let adminPaths = ['/user']
  let user = JSON.parse(localStorage.getItem('honey-user') || '{}')

  if (user.role !== '管理员' && adminPaths.includes(to.path)) {
    // 如果当前登录的用户不是管理员,然后当前的到达的路径是管理员才有权限访问的路径,那这个时候我就让用户去到一个没有权限的页面,不让他访问实际的页面
    next('/403')
  } else {
    next()
  }
})

在注册时选择不同身份登录

1. 在对应vue页面添加预计的框框

<el-form-item prop="role">
  <el-radio-group v-model="user.role">
    <el-radio label="管理员"></el-radio>
      <el-radio label="用户"></el-radio>
  </el-radio-group>
</el-form-item>

2. 在vue页面下方export default---data---rules添加角色提醒

role: [
  { required: true, message: '请选择角色', trigger: 'blur' },
],

3. 在WebController 中设置判断,即注册时该项不能为空

if(StrUtil.isBlank(user.getUsername())||StrUtil.isBlank(user.getPassword())||StrUtil.isBlank(user.getRole())){
    return Result.error("数据输入不合法");

}

4. 普通框架(未加入Mybaits),需人为补上该字段,使其插入数据库(记得然后项目重启

5. 简易版展示效果:

补充:想设置跳转页面链接很简单

只需要如下命令

<router-link to ="/">返回首页</router-link>

总结 

到此这篇关于前端实现不同角色登入展示不同页面效果的文章就介绍到这了,更多相关不同角色登入展示不同页面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue单元格多列合并的实现

    vue单元格多列合并的实现

    这篇文章主要介绍了vue单元格多列合并的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Vue3使用customRef封装防抖函数的方法详解

    Vue3使用customRef封装防抖函数的方法详解

    防抖函数的作用是高频率触发的事件,在指定的单位时间内,只响应最后一次,如果在指定的时间内再次触发,则重新计算时间,本文将给大家详细的介绍一下Vue3使用customRef封装防抖函数的方法,需要的朋友可以参考下
    2023-09-09
  • Vue中created和mounted使用场景分析

    Vue中created和mounted使用场景分析

    vue.js中created方法是一个生命周期钩子函数,一般可以在created函数中调用ajax获取页面初始化所需的数据,这篇文章主要介绍了Vue中created和mounted使用场景分析,需要的朋友可以参考下
    2023-05-05
  • vue3 onMounted异步函数同步请求async/await实现

    vue3 onMounted异步函数同步请求async/await实现

    这篇文章主要为大家介绍了vue3 onMounted初始化数据异步函数/同步请求async/await实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • vue+element下日期组件momentjs转换赋值问题解决

    vue+element下日期组件momentjs转换赋值问题解决

    这篇文章主要介绍了vue+element下日期组件momentjs转换赋值问题,记录下使用momentjs转换日期字符串赋值给element的日期组件报错问题,需要的朋友可以参考下
    2024-02-02
  • 基于vue-resource jsonp跨域问题的解决方法

    基于vue-resource jsonp跨域问题的解决方法

    下面小编就为大家分享一篇基于vue-resource jsonp跨域问题的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • vue虚拟化列表封装的实现

    vue虚拟化列表封装的实现

    这篇文章主要介绍了vue实现虚拟化列表封装方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • vue组件实现首次加载就触发watch

    vue组件实现首次加载就触发watch

    这篇文章主要介绍了vue组件实现首次加载就触发watch方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • 在Vue3中实现动态路由的示例代码

    在Vue3中实现动态路由的示例代码

    Vue3中的动态路由是一种高级功能,它允许你在URL中包含变量,这些变量可以在组件内部通过$route.params对象访问,动态路由通常用于构建可配置性强、更具灵活性的应用,本文详细介绍了如何在vue3中实现动态路由,需要的朋友可以参考下
    2024-07-07
  • vue开发调试神器vue-devtools使用详解

    vue开发调试神器vue-devtools使用详解

    这篇文章主要为大家详细介绍了vue开发调试神器vue-devtools的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07

最新评论