一看就會的vuex實(shí)現(xiàn)登錄驗(yàn)證(附案例)
一、vuex是啥?
Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測的方式發(fā)生變化。
簡單來說,Vuex 類似 Redux 的狀態(tài)管理器,用來管理Vue的所有組件狀態(tài)。
當(dāng)你打算開發(fā)大型單頁應(yīng)用(SPA),會出現(xiàn)多個(gè)視圖組件依賴同一個(gè)狀態(tài),來自不同視圖的行為需要變更同一個(gè)狀態(tài)。
遇到以上情況時(shí)候,你就應(yīng)該考慮使用Vuex了,它能把組件的共享狀態(tài)抽取出來,當(dāng)做一個(gè)全局單例模式進(jìn)行管理。這樣不管你在何處改變狀態(tài),都會通知使用該狀態(tài)的組件做出相應(yīng)修改。
vuex大體分為如下幾部分:
- state 用來數(shù)據(jù)共享數(shù)據(jù)存儲
- mutation 用來注冊改變數(shù)據(jù)狀態(tài)
- getters 用來對共享數(shù)據(jù)進(jìn)行過濾操作
- action 解決異步改變共享數(shù)據(jù)
- modules:store的子模塊,為了開發(fā)大型項(xiàng)目,方便狀態(tài)管理而使用的
二、vuex使用
1.首先創(chuàng)建一個(gè)vue-cli項(xiàng)目,這里不詳述。
vue init webpack mylogin
2.安裝vuex:
npm install vuex --save
3.在src目錄下新建文件夾store,用來存放vuex內(nèi)容
目錄結(jié)構(gòu)如下:

4.在main.js中引入vuex
import Vuex from 'vuex' import store from './store' Vue.use(Vuex)

5.在store文件夾下新建state.js,vuex用來存儲數(shù)據(jù)
內(nèi)容如下:
const state={
userInfo:''
}
export default state;
userInfo用來保存用戶信息,根據(jù)是否有值來判斷跳轉(zhuǎn)頁面。
6.在store文件夾下新建multation.js,用來修改vuex中存儲的數(shù)據(jù)
內(nèi)容如下:
const mutations={
login(state,v){
state.userInfo=v;
}
}
export default mutations;
7.在store文件夾下新建index.js,用來初始化vuex
內(nèi)容如下:
import Vue from 'vue'
import Vuex from 'vuex'
import state from './state'
import mutations from './multation'
Vue.use(Vuex);
const store =new Vuex.Store({
state,
mutations
})
export default store;
此時(shí)在瀏覽器中就可以看到如下(瀏覽器需增加插件vue devTools):

8.本項(xiàng)目界面如下
主頁面和登陸頁面

9.login.vue提交方法如下:
submitBtn(){
let me=this;
if(!me.user.username||!me.user.pwd){
alert("用戶名或密碼不能為空");
}
else {
this.$store.commit('login',this.user);
this.$router.push('./');
}
}
通過commit實(shí)現(xiàn)執(zhí)行multations里剛才定義的login方法。即當(dāng)點(diǎn)擊登陸時(shí)state中的userInfo已經(jīng)被賦值。接下來通過判斷此字段是否有值來進(jìn)行頁面跳轉(zhuǎn)。
10.在main.js用router.beforeEach方法對vuex中的userInfo進(jìn)行判斷
router.beforeEach(function(to,from,next){
if(store.state.userInfo||to.path==='/login'){
next();
}
else {
next({path:'/login'})
}
})
效果圖:

登陸后:

案例地址:https://github.com/myweiwei/vuex-login
將不斷更新完善,期待您的批評指正!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vue中登錄驗(yàn)證成功后保存token,并每次請求攜帶并驗(yàn)證token操作
- vue實(shí)現(xiàn)登錄驗(yàn)證碼
- vue+springboot實(shí)現(xiàn)登錄驗(yàn)證碼
- vue + typescript + 極驗(yàn)登錄驗(yàn)證的實(shí)現(xiàn)方法
- vue+egg+jwt實(shí)現(xiàn)登錄驗(yàn)證的示例代碼
- vuex + axios 做登錄驗(yàn)證 并且保存登錄狀態(tài)的實(shí)例
- vue router+vuex實(shí)現(xiàn)首頁登錄驗(yàn)證判斷邏輯
- Vue+Flask實(shí)現(xiàn)簡單的登錄驗(yàn)證跳轉(zhuǎn)的示例代碼
- Vue實(shí)戰(zhàn)之vue登錄驗(yàn)證的實(shí)現(xiàn)代碼
- VUE實(shí)現(xiàn)token登錄驗(yàn)證
相關(guān)文章
Vue3?Suspense實(shí)現(xiàn)優(yōu)雅處理異步數(shù)據(jù)加載
Suspense?是?Vue?3?中用于處理異步數(shù)據(jù)加載的特性,它使得在加載異步數(shù)據(jù)時(shí)可以提供更好的用戶體驗(yàn),下面小編就來和大家詳細(xì)講講Suspense如何優(yōu)雅處理異步數(shù)據(jù)加載吧2023-10-10
Vue3+Vite項(xiàng)目部署后刷新白屏問題的解決方法
Vue3 + Vite 項(xiàng)目部署后出現(xiàn)了手動刷新頁面時(shí)出現(xiàn)白屏的問題,下面小編就來和大家探討一下白屏出現(xiàn)的原因以及具體的解決方法,需要的可以參考下2025-03-03
Vue2和Vue3在v-for遍歷時(shí)ref獲取dom節(jié)點(diǎn)的區(qū)別及說明
這篇文章主要介紹了Vue2和Vue3在v-for遍歷時(shí)ref獲取dom節(jié)點(diǎn)的區(qū)別及說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
淺談vue項(xiàng)目重構(gòu)技術(shù)要點(diǎn)和總結(jié)
這篇文章主要介紹了淺談vue項(xiàng)目重構(gòu)技術(shù)要點(diǎn)和總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-01-01
Vue3生命周期Hooks原理與調(diào)度器Scheduler關(guān)系
這篇文章主要為大家介紹了Vue3生命周期Hooks原理與調(diào)度器Scheduler關(guān)系詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
Vue使用Echarts實(shí)現(xiàn)立體柱狀圖
這篇文章主要為大家詳細(xì)介紹了Vue使用Echarts實(shí)現(xiàn)立體柱狀圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
詳解VueJS 數(shù)據(jù)驅(qū)動和依賴追蹤分析
這篇文章主要介紹了詳解VueJS 數(shù)據(jù)驅(qū)動和依賴追蹤分析,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07

