若依框架根据当前登录人信息,显示不同的静态公司logo

1、在\src\store\modules\user.js文件新增所需要获取的用户信息。

xml 复制代码
const user = {
    state: {
        token: getToken(),
        id: '',
        name: '',
        avatar: '',
        // 新增deptId变量
        deptId: '',
        roles: [],
        permissions: []
    },
// 通过mutations修改State(数据仓库)中存储的数据,唯一方式
mutations: {
        SET_TOKEN: (state, token) => {
            state.token = token
        },
        SET_ID: (state, id) => {
            state.id = id
        },
        SET_NAME: (state, name) => {
            state.name = name
        },
        SET_AVATAR: (state, avatar) => {
            state.avatar = avatar
        },
        // 新增设置用户部门编号,根据此编号显示静态logo
        SET_DEPTID: (state, deptId) => {
            state.deptId = deptId
        },
        SET_ROLES: (state, roles) => {
            state.roles = roles
        },
        SET_PERMISSIONS: (state, permissions) => {
            state.permissions = permissions
        }
    },

        // 获取用户信息
        GetInfo({ commit, state }) {
            return new Promise((resolve, reject) => {
                getInfo().then(res => {
                    console.log('后端完整返回数据:', res);
                    const user = res.user
                    const deptId = user.deptId
                    const avatar = (user.avatar == "" || user.avatar == null) ? require("@/assets/images/login.jpg") : process.env.VUE_APP_BASE_API + user.avatar;
                    if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
                        commit('SET_ROLES', res.roles)
                        commit('SET_PERMISSIONS', res.permissions)
                    } else {
                        commit('SET_ROLES', ['ROLE_DEFAULT'])
                    }
                    commit('SET_ID', user.userId)
                    commit('SET_NAME', user.userName)
                    commit('SET_AVATAR', avatar)
                    // 将通过GetInfo获取到的deptId,提交mutation更新state中的deptId
                    commit('SET_DEPTID', deptId)
                    resolve(res)
                }).catch(error => {
                    reject(error)
                })
            })
        },

2、在\src\layout\components\Sidebar\Login.vue中获取state中存储的deptId(this.$store.state.user.deptId)信息,并判断显示对应的静态logo

xml 复制代码
<transition name="sidebarLogoFade">
  <router-link v-if="collapse" key="collapse" class="sidebar-logo-link" to="/">
    <img v-if="logo" :src="logo" class="sidebar-logo" />
    <h1  v-if="isShowTitle" class="sidebar-title" :style="{ color: sideTheme === 'theme-dark' ? variables.logoTitleColor : variables.logoLightTitleColor }">{{ title }} </h1>
  </router-link>
  <router-link v-else key="expand" class="sidebar-logo-link" to="/">
    <div :class="isShowTitle ? '' : 'image-wrapper'">
      <img v-if="logo" :src="logo" :class="isShowTitle ? 'sidebar-logo' : ''" />
      <h1 v-if="isShowTitle" class="sidebar-title" :style="{ color: sideTheme === 'theme-dark' ? variables.logoTitleColor : variables.logoLightTitleColor }">CHEMSUN </h1>
    </div>
  </router-link>
</transition>

// 导入用到的静态图片
import logoImg from '@/assets/logo/logo.png'
import vLogo from '@/assets/logo/vlogo.png'

computed: {
    // 获取当前的deptId,如果为111的话显示vexveLogo 否则logoImg
    logo() {
      const deptId = this.$store.state.user.deptId;
      return deptId === 111 ? vLogo : logoImg;
    }
    //  是否显示判断,deptId不等于111则为True
    isShowTitle() {
      const deptId = this.$store.state.user.deptId;
      return deptId !== 111;
    }
  },

注意state中要声明你所需要的变量名,如果不加的话就会导致响应性缺失,但是也不会有很大影响,功能也能正常实现。只不过在更改值的时候并不会立即生效,因为Vue 会在初始化时对state中的属性做「响应式监听」,当你通过 mutation 修改它们时,所有使用这些属性的组件会自动更新视图;

但是如果仅在mutations中动态添加的deptId:Vue 没有对这个属性做监听,哪怕你后续通过SET_DEPTID修改它的值,使用deptId的组件不会自动刷新(除非组件重新渲染,比如路由跳转)。

最关键的问题:你能调取到值,但这个deptId不具备 Vue 的响应式特性!

相关推荐
阿星AI工作室13 小时前
一个简单Demo彻底理解前后端怎么连的丨Figma + Supabase + Vercel
前端·人工智能
aircrushin13 小时前
一拍即传的平替,完全免费的实时照片墙!
前端
鹏北海15 小时前
JSBridge 原理详解
前端
孟健15 小时前
我的网站被黑了:一天灌入 227 万条垃圾数据,AI 写的代码差点让我社死
前端
anOnion15 小时前
构建无障碍组件之Checkbox pattern
前端·html·交互设计
IT枫斗者17 小时前
IntelliJ IDEA 2025.3史诗级更新:统一发行版+Spring Boot 4支持,这更新太香了!
java·开发语言·前端·javascript·spring boot·后端·intellij-idea
N***p36517 小时前
Spring Boot项目接收前端参数的11种方式
前端·spring boot·后端
享誉霸王18 小时前
15、告别混乱!Vue3复杂项目的规范搭建与基础库封装实战
前端·javascript·vue.js·前端框架·json·firefox·html5
a11177619 小时前
飞机躲避炸弹 网页游戏
前端·开源·html·threejs
夏乌_Wx19 小时前
mybash:简易 Shell 实现的设计思路与核心模块解析
linux·服务器·前端