vue獲取或者改變vuex中的值方式
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中的值
<script> import { mapState, mapActions,mapMutations } from "vuex" export default { name:"index", data() { return { } }, computed:{ ...mapState({ isLogin:state=>state.isLogin }),//等同于==>...mapState(['isLogin']);映射 this.isLogin 為 this.$store.state.isLogin }, mounted(){ console.log("[mapState]",this.isLogin) this.$store.state.isLogin;//等同于==》this.isLogin this.$store.dispatch("getLogin",true);//等同于==》this.getLogin(true);dispatch觸發(fā)actions里的方法,Action 提交的是 mutation,而不是直接變更狀態(tài),Action 可以包含任意異步操作 this.$store.commit("logout");//等同于==》this.logout();commit觸發(fā)mutations里的方法,更改 Vuex 的 store 中的狀態(tài)的唯一方法是提交 mutation console.log(this.$store.state.isLogin) console.log(localStorage.getItem("isLogin")) }, methods:{ ...mapMutations(["logout"]),// 將 `this.logout()` 映射為 `this.$store.commit('logout')` ...mapActions(["getLogin"]),// 將 `this.getLogin()` 映射為 `this.$store.dispatch('getLogin')` } } </script>
監(jiān)聽vuex值變化實(shí)時(shí)改變
問題如圖
頭部是一個(gè)組件,想在這個(gè)頁面修改用戶名點(diǎn)擊確認(rèn)修改后,頭部名稱跟到變化。
思路
用戶名在登錄成功過后,存在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)
好??!重要的來了,就是在頭部組件里面寫監(jiān)聽事件,監(jiān)聽用戶名改變時(shí),隨著變化
watch:{ '$store.state.userName':function(){ //監(jiān)聽vuex中userName變化而改變header里面的值 this.userName=this.$store.state.userName; } },
這樣就可以實(shí)現(xiàn)在其他頁面改變用戶名達(dá)到實(shí)時(shí)變化
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vuecli3.0腳手架搭建及不同的打包環(huán)境配置vue.config.js的詳細(xì)過程
這篇文章主要介紹了vuecli3.0腳手架搭建及不同的打包環(huán)境配置vue.config.js的詳細(xì)過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01vue 解決uglifyjs-webpack-plugin打包出現(xiàn)報(bào)錯(cuò)的問題
這篇文章主要介紹了vue 解決uglifyjs-webpack-plugin打包出現(xiàn)報(bào)錯(cuò)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08vue style屬性設(shè)置背景圖片的相對路徑無效的解決
這篇文章主要介紹了vue style屬性設(shè)置背景圖片的相對路徑無效的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10使用vite構(gòu)建vue3項(xiàng)目的方法步驟
本文主要介紹了使用vite構(gòu)建vue3項(xiàng)目的方法步驟,vite支持性肯定比傳統(tǒng)的打包工具好,下面我們就來介紹一下使用vite構(gòu)建vue3項(xiàng)目,感興趣的可以參考一下2023-05-05關(guān)于Vue實(shí)現(xiàn)組件信息的緩存問題
這篇文章主要介紹了關(guān)于Vue實(shí)現(xiàn)組件信息的緩存問題的相關(guān)資料,需要的朋友可以參考下2017-08-08vue 導(dǎo)航守衛(wèi)和axios攔截器有哪些區(qū)別
這篇文章主要介紹了vue 導(dǎo)航守衛(wèi)和axios攔截器有哪些區(qū)別,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下2020-12-12Jenkins自動化部署Vue項(xiàng)目的方法實(shí)現(xiàn)
本文主要介紹了Jenkins自動化部署Vue項(xiàng)目的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04