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

RuoyiApp 在vuex,state存储nickname vue2

发现一个很头疼问题,RuoyiApp(uniapp)小程序在文件中随时获取nickname获取不到,因为在登录的时候没有存储(或许官方有解决方案) 接下来使用vuex开始破局 添加的文件前面都有一行++++++

1.user.js

import config from '@/config'
import storage from '@/utils/storage'
import constant from '@/utils/constant'
import { isHttp, isEmpty } from "@/utils/validate"
import { login, logout, getInfo } from '@/api/login'
import { getToken, setToken, removeToken } from '@/utils/auth'
import defAva from '@/static/images/profile.jpg'const baseUrl = config.baseUrlconst user = {state: {token: getToken(),id: storage.get(constant.id),name: storage.get(constant.name),++++++	nickName: storage.get(constant.nickName),avatar: storage.get(constant.avatar),roles: storage.get(constant.roles),permissions: storage.get(constant.permissions)
//	permissions: [].concat(storage.get(constant.permissions) || [])},mutations: {SET_TOKEN: (state, token) => {state.token = token},SET_ID: (state, id) => {state.id = idstorage.set(constant.id, id)},SET_NAME: (state, name) => {state.name = namestorage.set(constant.name, name)},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)}++++++,
++++++SET_NICKNAME:(state,nickName) => {
++++++state.nickName = nickName
++++++storage.set(constant.nickName,nickName)
++++++}},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.userconsole.log("user",user)console.log("JSON_user",JSON.stringify(user))let avatar = user.avatar || ""if (!isHttp(avatar)) {avatar = (isEmpty(avatar)) ? defAva : baseUrl + avatar}const userid = (isEmpty(user) || isEmpty(user.userId)) ? "" : user.userIdconst username = (isEmpty(user) || isEmpty(user.userName)) ? "" : user.userName
++++++const nickName = (isEmpty(user) || isEmpty(user.nickName)) ? "" : user.nickNameconsole.log("nickName",nickName)if (res.roles && res.roles.length > 0) {commit('SET_ROLES', res.roles)commit('SET_PERMISSIONS', res.permissions)} else {commit('SET_ROLES', ['ROLE_DEFAULT'])}commit('SET_ID', userid)commit('SET_NAME', username)commit('SET_AVATAR', avatar)
++++++commit('SET_NICKNAME', nickName)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.constant.js

const constant = {avatar: 'user_avatar',id: 'user_id',name: 'user_name',
++++++nickName: 'nick_name',roles: 'user_roles',permissions: 'user_permissions'}export default constant

3.getter.js

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

4.storage.js

import constant from './constant'// 存储变量名
let storageKey = 'storage_data'// 存储节点变量名
++++++let storageNodeKeys = [constant.avatar, constant.id, constant.name, constant.roles, constant.permissions,constant.nickName]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

5.使用

<script>import storage from '@/utils/storage'import constant from '@/utils/constant'export default {data() {return {baseFormData:{name: storage.get(constant.nickName),id: storage.get(constant.name),}}},methods: {}}
</script>

或者

this.$store.state.user.nickName
http://www.dtcms.com/a/569524.html

相关文章:

  • 常见的网站类型有哪些wordpress收费会员
  • 建设银行成都开发中心网站saas云建站
  • 视频网站如何做爱奇艺做任务领vip网站
  • 用python可视化分析上海教育中考新政
  • MySQL的UPPER函数介绍
  • 自己搭建一个网站我做钓鱼网站自首了
  • 专用主机方式建设网站用discuz做的大网站
  • [特殊字符] Java/Vue 实现体育比分直播系统,支持多端实时更新
  • 沈阳哪个网站建设公司好重庆网站制作一般多少钱
  • 用vscode连接远端ubuntu无法git push,vscode无法连接centos
  • 商业门户网站怎么运营淘宝关键词怎么选取
  • oj 素数个数 难
  • 全球前10网站开发语言百度做网站需要多少钱
  • Affinity三大专业工具整合免费开放
  • ZSAR配置PDUR模块
  • 基于springboot的校园社团信息管理系统开发与设计
  • 鹿寨县住房和城乡建设局网站网站改版 英文
  • 为什么Redis的操作是原子性的?如何保证原子性的?
  • C++17 异构(tuple)与多模态数据结构(variant)
  • 【SpringBoot】玩转 Spring Boot 日志:级别划分、持久化、格式配置及 Lombok 简化使用
  • 火山引擎数智平台VeDI重磅发布“AI助手”:以大模型驱动数据飞轮,赋能非技术人员高效“看数、用数”
  • 前言:可视化搭建诞生背景 什么是可视化
  • 个人博客网站怎么注册网站怎么做会员系统
  • 山东省建设厅招标网站首页c可以做网站吗
  • 【Solidity 从入门到精通】第3章 Solidity 基础语法详解
  • 【仓颉纪元】仓颉实战深度复盘:21 天打造鸿蒙天气应用
  • Idea(2023版)使用Svn
  • windows SVN 修改提交作者、提交注释、提交日期
  • 网站空间购买哪家好wordpress 字体颜色
  • 网站定制哪个好建筑模板厚度一般是多少