您现在的位置是:网站首页> 编程资料编程资料
vue获取或者改变vuex中的值方式_vue.js_
2023-05-24
403人已围观
简介 vue获取或者改变vuex中的值方式_vue.js_
vue获取或改变vuex的值
store–>index.js
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { isLogin:localStorage.getItem("isLogin")?localStorage.getItem("isLogin"):false,//判断是否登录 }, mutations: { //判断是否登录 setLogin(state,payload){ state.isLogin=payload localStorage.setItem("isLogin",state.isLogin) }, //退出登录 logout(state){ console.log("[退出登录]",state) state.isLogin=false localStorage.clear();//清除本地缓存 } }, actions: { getLogin(context,payload){ context.commit("setLogin",payload) } }, modules: { } }) 在页面中使用或者修改vuex中的值
监听vuex值变化实时改变
问题如图

头部是一个组件,想在这个页面修改用户名点击确认修改后,头部名称跟到变化。
思路
用户名在登录成功过后,存在vuex里面并且保存在本地(防止刷新消失)
this.$store.commit('set_userName',res.data.data.username)vuex中state.js :
userName:localStorage.getItem('userName') ? localStorage.getItem('userName') : '',mutations.js
set_mobile(state,mobile){ state.mobile=mobile localStorage.setItem('mobile', mobile); },要取用户名就用
this.$store.state.userName;
要存用户名就用
this.$store.commit('set_userName',this.newName)好!!重要的来了,就是在头部组件里面写监听事件,监听用户名改变时,随着变化
watch:{ '$store.state.userName':function(){ //监听vuex中userName变化而改变header里面的值 this.userName=this.$store.state.userName; } },这样就可以实现在其他页面改变用户名达到实时变化
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
相关内容
- Vue项目导入导出文件功能以及导出文件后乱码问题及解决_vue.js_
- ElementPlus el-message-box样式错位问题及解决_vue.js_
- element组件中自定义组件的样式不生效问题(vue scoped scss无效)_vue.js_
- element-plus按需引入后ElMessage与ElLoading在页面中的使用_vue.js_
- element-ui自定义message-box自定义样式不生效的解决_vue.js_
- vue里面的el-select绑定默认值方式_vue.js_
- vue中使用render封装一个select组件_vue.js_
- 关于element-ui 单选框默认值不选中的解决_vue.js_
- vue实现el-select默认选择第一个或者第二个_vue.js_
- JavaScript onclick与addEventListener使用的区别介绍_javascript技巧_
