Vue實戰(zhàn)之vue登錄驗證的實現(xiàn)代碼
最近一直在擼一個給大學生新生用的產品,在擼的時候有時候會發(fā)現(xiàn)自己力不從心,是不是我的能力下降,是不是我該放棄我的最熱愛的事業(yè)了?這對我的心靈造成了巨大的傷害,所以我決定向蒼老師起誓一定練好我這雙手——好好寫代碼(想多的同學趕緊去面壁5秒鐘再過來往下看)~~~
我做的這個產品是課堂在線編程教學工具,由于涉及到商業(yè)問題,這里就不能和大家分享了,但是我可以把里面我認為很牛(zhuang)X(bi)的技術和大家分享分享啊。
如果你覺得我寫的很 low的話歡迎加入igeekbar裙里來噴我啊,我在那里等你啊,我相信贊美會有很多故事喲。哈哈,廢話不多說了,進入干貨分享啦~~~
先從登錄分享吧,登錄是我寫完項目后加上的,一開始沒有考慮到登錄問題,后來加的,看了一些人分享的登錄,感覺都太牛逼了(主要我理解能力差看不懂)。最后自己搞了一套。
使用的技術:
- vue
- vue-router
- vuex
首先明確的一點vue是一個寫但頁面的框架,以前在做登錄的時候,也許是后端來控制登錄的狀態(tài),把登陸的信息會放在cookie里。前端也可以做登錄驗證的,這主要是基于但頁面引入路由的功能得以實現(xiàn)的。
在vue-router里有個鉤子函數(shù) beforeEach (導航守衛(wèi))多霸氣的名字,故名YY就是這是我家沒我的邀請名片都給我滾蛋,還想過來和我一起看蒼老師。beforeEach 接受三個參數(shù)(to, from, next)分別是to: 小伙要去哪里, from: 小伙從那里來, next: 美女您請進,小心路滑啊。姑且你們認為我寫的很形象啊,如果你感到不服去看 文檔 ?。?/p>
理解里 beforeEach 那我們就可以區(qū)搞事情了?;镜乃悸肥牵?/p>
- 我要從router的信息里面拿到 meta 用戶的源信息,如果沒有就讓這屌絲滾蛋,收拾帥氣點再來(也就是去登錄)
- 如果沒有源信息的話,就等跳到 igeekbar 裙里來瞅瞅,拿到入場圈(也就是登錄后拿到了返回結果并存在router的源信息中,用于之后路由跳轉的驗證)
寫到這里突然感覺這貌似誰都懂的啊,不管了寫這么多,就當你是小白吧(哈哈哈)
下面直接上代碼:
在 router.js 路由中添加一下代碼
// router.js
router.beforeEach((to, from, next) => {
if (!to.meta.user) {
// todo 請求接口獲取數(shù)據(jù)
loadUserData().then(user => {
// 存放源信息
to.meta.user = user
// 存在 vuex 中
store.state.user = user
if(user){
next()
}else{
next({
path: '/'
})
}
})
} else {
next()
}
})
統(tǒng)一處理接口的文件api.js
// api.js
import axios from 'axios'
// 封裝ajax 的 fetch
export let fetch = (method, url, data, forceLogin = true) => {
return new Promise((resolve, reject) => {
axios({
...data,
method: method,
url: url
}).then(response => {
resolve(response.data)
}).catch(err => {
reject(err)
})
})
}
// 獲取用戶信息
export let loadUserData = () => {
return new Promise((resolve, reject) => {
let user = null
let cacheKey = 'authUserJsonStr'
let authUserJsonStr = sessionStorage.getItem(cacheKey)
if (authUserJsonStr) {
user = JSON.parse(sessionStorage.getItem(cacheKey))
resolve(user)
} else {
fetch('GET', '/api/auth_info/', {}, false).then((data) => {
user = data
sessionStorage.setItem(cacheKey, JSON.stringify(user))
resolve(user)
}).catch(() => {
resolve(null)
})
}
})
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Vue 實現(xiàn)登錄界面驗證碼功能
- vue實現(xiàn)登錄頁面的驗證碼以及驗證過程解析(面向新手)
- vue 登錄滑動驗證實現(xiàn)代碼
- 使用vue-route 的 beforeEach 實現(xiàn)導航守衛(wèi)(路由跳轉前驗證登錄)功能
- Vue中的驗證登錄狀態(tài)的實現(xiàn)方法
- vue登錄注冊及token驗證實現(xiàn)代碼
- vue router+vuex實現(xiàn)首頁登錄驗證判斷邏輯
- Vue中登錄驗證成功后保存token,并每次請求攜帶并驗證token操作
- vuex + axios 做登錄驗證 并且保存登錄狀態(tài)的實例
- vue實現(xiàn)登錄時滑塊驗證
相關文章
vue路由跳轉打開新窗口(window.open())和關閉窗口(window.close())
這篇文章主要介紹了vue路由跳轉打開新窗口(window.open())和關閉窗口(window.close())問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
vue最強table vxe-table 虛擬滾動列表 前端導出問題分析
最近遇到個問題,后臺一次性返回2萬條列表數(shù)據(jù)并且需求要求所有數(shù)據(jù)必須全部展示,不能做假分頁,怎么操作呢,下面通過本文介紹下vue最強table vxe-table 虛擬滾動列表 前端導出問題,感興趣的朋友一起看看吧2023-10-10
element?ui富文本編輯器的使用效果與步驟(quill-editor)
富文本編輯器在任何項目中都會用到,在Element中我們推薦vue-quill-editor組件,下面這篇文章主要給大家介紹了關于element?ui富文本編輯器的使用效果與步驟(quill-editor)的相關資料,需要的朋友可以參考下2022-10-10
Vue Cli與BootStrap結合實現(xiàn)表格分頁功能
這篇文章主要介紹了Vue Cli與BootStrap結合實現(xiàn)表格分頁功能,需要的朋友可以參考下2017-08-08

