当前位置: 首页 > news >正文

ruoyi-app前端在缓存中添加nick_name和user_id属性值

在这里插入图片描述

需求

ruoyi-app原生自带只有avatar、name、roles、permissions;在显示中,我们大多数需要nick_name、user_id;当然获取方式也可以通过name去调用接口查询,但我想偷个懒。

代码

代码已经调好的,复制即用;至于修改点,细心一点应该能自己发现

1、修改 store/modules/user.js 文件

import config from '@/config'
import storage from '@/utils/storage'
import constant from '@/utils/constant'
import { login, logout, getInfo } from '@/api/login'
import { getToken, setToken, removeToken } from '@/utils/auth'const baseUrl = config.baseUrlconst user = {state: {token: getToken(),name: storage.get(constant.name),userId: storage.get(constant.userId),nickName: storage.get(constant.nickName),avatar: storage.get(constant.avatar),roles: storage.get(constant.roles),permissions: storage.get(constant.permissions)},mutations: {SET_TOKEN: (state, token) => {state.token = token},SET_NAME: (state, name) => {state.name = namestorage.set(constant.name, name)},SET_USER_ID: (state, userId) => {state.userId = userIdstorage.set(constant.userId, userId)},SET_NICK_NAME: (state, nickName) => {state.nickName = nickNamestorage.set(constant.nickName, nickName)},SET_AVATAR: (state, avatar) => {state.avatar = avatarstorage.set(constant.avatar, avatar)},SET_ROLES: (state, roles) => {state.roles = rolesstorage.set(constant.roles, roles)},SET_PERMISSIONS: (state, permissions) => {state.permissions = permissionsstorage.set(constant.permissions, permissions)}},actions: {// 登录Login({ commit }, userInfo) {const username = userInfo.username.trim()const password = userInfo.passwordconst code = userInfo.codeconst uuid = userInfo.uuidreturn new Promise((resolve, reject) => {login(username, password, code, uuid).then(res => {setToken(res.token)commit('SET_TOKEN', res.token)resolve()}).catch(error => {reject(error)})})},// 获取用户信息GetInfo({ commit, state }) {return new Promise((resolve, reject) => {getInfo().then(res => {const user = res.userconst avatar = (user == null || user.avatar == "" || user.avatar == null) ? require("@/static/images/profile.jpg") : baseUrl + user.avatarconst username = (user == null || user.userName == "" || user.userName == null) ? "" : user.userNameconst userId = (user == null || user.userId == "" || user.userId == null) ? "" : user.userIdconst nickName = (user == null || user.nickName == "" || user.nickName == null) ? "" : user.nickNameif (res.roles && res.roles.length > 0) {commit('SET_ROLES', res.roles)commit('SET_PERMISSIONS', res.permissions)} else {commit('SET_ROLES', ['ROLE_DEFAULT'])}commit('SET_NAME', username)commit('SET_USER_ID', userId)commit('SET_NICK_NAME', nickName)commit('SET_AVATAR', avatar)resolve(res)}).catch(error => {reject(error)})})},// 退出系统LogOut({ commit, state }) {return new Promise((resolve, reject) => {logout(state.token).then(() => {commit('SET_TOKEN', '')commit('SET_ROLES', [])commit('SET_PERMISSIONS', [])removeToken()storage.clean()resolve()}).catch(error => {reject(error)})})}}
}export default user

2、修改 store/getter.js 文件

const getters = {token: state => state.user.token,avatar: state => state.user.avatar,name: state => state.user.name,userId: state => state.user.userId,nickName: state => state.user.nickName,roles: state => state.user.roles,permissions: state => state.user.permissions
}
export default getters

3、修改 utils/storage.js 文件

import constant from './constant'// 存储变量名
let storageKey = 'storage_data'// 存储节点变量名
let storageNodeKeys = [constant.avatar, constant.name,constant.userId,constant.nickName, constant.roles, constant.permissions]const storage = {set: function(key, value) {if (storageNodeKeys.indexOf(key) != -1) {let tmp = uni.getStorageSync(storageKey)tmp = tmp ? tmp : {}tmp[key] = valueuni.setStorageSync(storageKey, tmp)}},get: function(key) {let storageData = uni.getStorageSync(storageKey) || {}return storageData[key] || ""},remove: function(key) {let storageData = uni.getStorageSync(storageKey) || {}delete storageData[key]uni.setStorageSync(storageKey, storageData)},clean: function() {uni.removeStorageSync(storageKey)}
}export default storage

4、修改 utils/constant.js 文件

const constant = {avatar: 'vuex_avatar',name: 'vuex_name',userId: 'vuex_user_id',nickName: 'vuex_nick_name',roles: 'vuex_roles',permissions: 'vuex_permissions'}export default constant

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • GeoStudio2024:地质工程的瑰宝下载安装介绍
  • std::vector的reserve(), resize()和shrink_to_fit()
  • 559. N 叉树的最大深度(递归法)
  • wp-autopost-pro 3.7.8最新完美版
  • 神经网络——非线性激活
  • wooyu漏洞库YYDS!!!入门之道:重现乌云漏洞库
  • 【Java EE】深入理解 Java 线程的生命周期与状态转换
  • Python 和 PyCharm 安装(傻瓜式)
  • C 06 编译4阶段
  • Linux 下 gdb 的使用
  • 10个企业网络安全建议,解决99%的网络安全问题
  • Clickhouse 二进制安装
  • 一个资深测试工程师面试一来就问我这些题目
  • 《黑神话·悟空》:国产3A大作背后是用什么语言开发的?
  • OpenGL实现3D游戏编程【连载5】——纹理坐标、纹理贴图
  • 分享的文章《人生如棋》
  • [iOS]Core Data浅析一 -- 启用Core Data
  • [微信小程序] 使用ES6特性Class后出现编译异常
  • 【前端学习】-粗谈选择器
  • css布局,左右固定中间自适应实现
  • ES学习笔记(10)--ES6中的函数和数组补漏
  • express + mock 让前后台并行开发
  • github指令
  • Git学习与使用心得(1)—— 初始化
  • RxJS: 简单入门
  • windows下使用nginx调试简介
  • XForms - 更强大的Form
  • 复习Javascript专题(四):js中的深浅拷贝
  • ------- 计算机网络基础
  • 深度学习中的信息论知识详解
  • 数据库写操作弃用“SELECT ... FOR UPDATE”解决方案
  • 推荐一个React的管理后台框架
  • 小程序开发之路(一)
  • 小试R空间处理新库sf
  • 用quicker-worker.js轻松跑一个大数据遍历
  • ​iOS实时查看App运行日志
  • ​力扣解法汇总1802. 有界数组中指定下标处的最大值
  • ​如何防止网络攻击?
  • $ is not function   和JQUERY 命名 冲突的解说 Jquer问题 (
  • (C语言)逆序输出字符串
  • (附源码)springboot课程在线考试系统 毕业设计 655127
  • (附源码)SSM环卫人员管理平台 计算机毕设36412
  • (十六)一篇文章学会Java的常用API
  • (十七)devops持续集成开发——使用jenkins流水线pipeline方式发布一个微服务项目
  • (算法)求1到1亿间的质数或素数
  • (算法设计与分析)第一章算法概述-习题
  • (原創) 如何動態建立二維陣列(多維陣列)? (.NET) (C#)
  • (转)visual stdio 书签功能介绍
  • (转)重识new
  • (转载)OpenStack Hacker养成指南
  • (转载)虚函数剖析
  • *(长期更新)软考网络工程师学习笔记——Section 22 无线局域网
  • .bat批处理(八):各种形式的变量%0、%i、%%i、var、%var%、!var!的含义和区别
  • .naturalWidth 和naturalHeight属性,
  • .NET 4.0中的泛型协变和反变