vue-element-admin按鈕級(jí)權(quán)限管控的實(shí)現(xiàn)
隨著軟件的發(fā)展,網(wǎng)站從最初的滿足用戶業(yè)務(wù)需求到提升用戶。就比如一個(gè)按鈕只要求權(quán)限方面的管控我們可以通過(guò) shiro,注解等方式來(lái)實(shí)現(xiàn),但是頁(yè)面上用戶點(diǎn)擊后沒(méi)反應(yīng)或者點(diǎn)擊后彈框沒(méi)權(quán)限,這顯然不是一個(gè)好的用戶體驗(yàn),因此通過(guò)前端來(lái)實(shí)現(xiàn)權(quán)限管控也是很有必要的。
思路
1.獲取按鈕權(quán)限
2.按鈕權(quán)限保存在前端全局中 vuex
3.頁(yè)面加載按鈕時(shí)通過(guò)判斷權(quán)限的存在與否,控制按鈕的顯示隱藏或者樣式選擇
PS:事實(shí)證明,思路清晰,實(shí)現(xiàn)起來(lái)就很容易,沒(méi)幾行代碼
表結(jié)構(gòu)與數(shù)據(jù)
就表結(jié)構(gòu)方面設(shè)計(jì)上不管有哪些字段,我們需要一個(gè)字段來(lái)存儲(chǔ)唯一權(quán)限,其他都是浮云,如圖
打印看看獲取到的數(shù)據(jù)
可以看到我只返回了權(quán)限數(shù)組,因?yàn)槠渌侄螞](méi)有意思,當(dāng)然直接返回對(duì)象也是 ok 的
實(shí)現(xiàn)
先來(lái)添加下 vuex 全局變量,方便后面獲取到按鈕權(quán)限后進(jìn)行存儲(chǔ)
/src/store/modules/user
新增 button 全局變量,并在新增 mutations 操作 button
為啥是在這,因?yàn)榘粹o的權(quán)限是屬于每個(gè)用戶的
/src/store/getters
使用時(shí)我們一般需要通過(guò)這個(gè)東西來(lái)獲取全局變量中的值
這個(gè) state.user.button 以我的理解就是上圖中 user 對(duì)象下的 button
/src/store/modules/user
回到 user 文件,現(xiàn)在我們可以把取到的 button 權(quán)限放到全局變量中就行了
做過(guò)權(quán)限模塊的都知道這個(gè) GetUserInfo 方法,每次緩存失效后,都會(huì)調(diào)用這個(gè)方法去獲取必要的用戶信息,這里按鈕權(quán)限我也是在這里直接返回獲取。
如果說(shuō)你的按鈕權(quán)限時(shí)單獨(dú)寫的,你也可以在這個(gè)文件里寫個(gè)獲取的方法,然后再 permission 文件里去調(diào)用,如圖
當(dāng)然我不太建議單獨(dú)去獲取,因?yàn)橛捎趘ue自身特性的原因,vuex中的數(shù)據(jù)在頁(yè)面刷新之后其中的數(shù)據(jù)會(huì)初始化,也就是數(shù)據(jù)沒(méi)了,這個(gè)時(shí)候就會(huì)去調(diào)用后臺(tái)去獲取數(shù)據(jù),如果每次都去單獨(dú)獲取,在高并發(fā)等情況下這種頻繁的重復(fù)數(shù)據(jù)的請(qǐng)求會(huì)給數(shù)據(jù)庫(kù)帶來(lái)巨大的壓力,因此像一些用戶權(quán)限數(shù)據(jù),我比較建議在登陸時(shí)統(tǒng)一獲取后保存到 redis 這種地方,以后的請(qǐng)求都只需要從 redis 取就可以了,效率上也會(huì)得到巨大的提升。
按鈕調(diào)用
調(diào)用就很簡(jiǎn)單了,直接獲取全局中的權(quán)限,用 v-if 判斷是否包含這個(gè)按鈕就行了,includes 后面的字符串就是對(duì)應(yīng)這個(gè)按鈕的權(quán)限
PS:如果存儲(chǔ)起來(lái)的不是這種簡(jiǎn)單的字符串?dāng)?shù)組,也可以改為 some 函數(shù)去判斷
到此這篇關(guān)于vue-element-admin按鈕級(jí)權(quán)限管控的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)vue-element-admin按鈕權(quán)限內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue單頁(yè)應(yīng)用的內(nèi)存泄露定位和修復(fù)問(wèn)題小結(jié)
系統(tǒng)進(jìn)程不再用到的內(nèi)存,沒(méi)有及時(shí)釋放,就叫做內(nèi)存泄漏(memory leak)。這篇文章主要介紹了vue單頁(yè)應(yīng)用的內(nèi)存泄露定位和修復(fù),需要的朋友可以參考下2019-08-08Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲(chǔ)的使用
這篇文章主要介紹了Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲(chǔ)的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10vue頁(yè)面加載時(shí)的進(jìn)度條功能(實(shí)例代碼)
這篇文章主要介紹了vue頁(yè)面加載時(shí)的進(jìn)度條功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01Vue中禁止編輯的常見(jiàn)方法(以禁止編輯輸入框?yàn)槔?
在我們開(kāi)發(fā)項(xiàng)目的時(shí)候,有時(shí)候我們不希望用戶對(duì)我們的頁(yè)面進(jìn)行操作,尤其是輸入框之類的,這篇文章主要給大家介紹了Vue中禁止編輯的常見(jiàn)方法,文中介紹的方法主要以禁止編輯輸入框?yàn)槔?需要的朋友可以參考下2024-02-02vue使用video插件vue-video-player的示例
這篇文章主要介紹了vue使用video插件vue-video-player的示例,幫助大家更好的理解和使用vue插件,感興趣的朋友可以了解下2020-10-10vue實(shí)現(xiàn)四級(jí)導(dǎo)航及驗(yàn)證碼的方法實(shí)例
我們?cè)谧鲰?xiàng)目經(jīng)常會(huì)遇到多級(jí)導(dǎo)航這個(gè)需求,所以下面這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)四級(jí)導(dǎo)航及驗(yàn)證碼的相關(guān)資料,文章通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07el-checkbox-group?的v-model無(wú)法綁定對(duì)象數(shù)組的問(wèn)題解決
elementUI官方文檔中el-checkbox-group組件綁定的都為一維數(shù)組,本文主要介紹了解決el-checkbox-group?的v-model無(wú)法綁定對(duì)象數(shù)組,感興趣的可以了解一下2023-05-05解決vue的router組件component在import時(shí)不能使用變量問(wèn)題
這篇文章主要介紹了解決vue的router組件component在import時(shí)不能使用變量問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07