這篇文章主要介紹“vue-router中如何實(shí)現(xiàn)權(quán)限控制”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“vue-router中如何實(shí)現(xiàn)權(quán)限控制”文章能幫助大家解決問題。
10多年的昌都網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營(yíng)銷推廣的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整昌都建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。成都創(chuàng)新互聯(lián)公司從事“昌都網(wǎng)站設(shè)計(jì)”,“昌都網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
在vue-router控制前端權(quán)限是常見需求:
有一種做法是直接在后端完成判斷,提供頁面列表和操作列表,在前端進(jìn)行渲染,但這個(gè)方案并不優(yōu)雅,前后端耦合度比較高。
比較常見的做法是把登錄頁面獨(dú)立在router之外,專門寫一個(gè)權(quán)限控制文件,在登錄之后根據(jù)用戶權(quán)限加載router,之后把權(quán)限作為參數(shù)傳入各種組件中,以控制元素的渲染。這個(gè)方法比較合理,沒有什么額外的開銷,只是需要獨(dú)立寫一個(gè)登錄頁面和權(quán)限控制文件比較麻煩一些,特別是對(duì)一些小項(xiàng)目而言。
我們希望還有更簡(jiǎn)單的方式。這個(gè)時(shí)候梳理一下需求,我們的主要目標(biāo)是:
菜單欄控制,根據(jù)權(quán)限渲染可以進(jìn)入的頁面菜單;
操作按鈕權(quán)限控制,沒有操作權(quán)限的不予顯示;
如果有人通過直接點(diǎn)擊鏈接或輸入地址進(jìn)入沒有權(quán)限的頁面,則進(jìn)行攔截;
第一、第二個(gè)目標(biāo)是容易實(shí)現(xiàn)的,把權(quán)限列表傳入對(duì)應(yīng)組件,通過v-if判斷即可,需要解決的是越權(quán)頁面的攔截問題。在上面常見的做法中,為了實(shí)現(xiàn)攔截,單獨(dú)寫了一個(gè)登錄頁面,登錄之后再根據(jù)權(quán)限加載路由,這樣,沒有權(quán)限的路由根本不會(huì)加載,于是被導(dǎo)向404頁面。
那么,現(xiàn)在的問題是,怎么樣會(huì)有更簡(jiǎn)單的方式?
顯然,如果我們不想單獨(dú)寫login頁面,那么router在登錄前就完成加載了。如果無法通過router自動(dòng)將越權(quán)頁面導(dǎo)向404頁面,我們能做的,只能手動(dòng)引導(dǎo)了。思路清楚了,實(shí)現(xiàn)起來就毫無壓力:
根據(jù)vue組件的生命周期,我們可以在mounted鉤子上進(jìn)行權(quán)限判斷,如果通過props傳入的用戶權(quán)限列表沒有對(duì)應(yīng)權(quán)限,就跳轉(zhuǎn)頁面到404:
mounted () { if (!this.check_user_privilege (current_page)) { this.$Message.error('權(quán)限不足'); this.$router.push('404'); } }
當(dāng)然,事實(shí)上vue-router也提供了頁面跳轉(zhuǎn)時(shí)的鉤子方法,全局的有beforeEach、afterEach等,我們希望直接在組件內(nèi)使用,則可以使用beforeRouteEnter方法,在進(jìn)入頁面時(shí)進(jìn)行判斷,比如:
beforeRouteEnter (to, from, next) { next(vm => { if (!vm.check_user_privilege (current_page)) { vm.$Message.error('權(quán)限不足'); vm.$router.push('404'); } }) },
具體可以參考[文檔]。
當(dāng)然,就這個(gè)例子來說,用vue-router提供的鉤子還不如直接在mounted寫判斷條件,因?yàn)閎eforeRouteEnter方法中的next需要調(diào)用組件參數(shù),是在mounted執(zhí)行之后才執(zhí)行的,而我們又經(jīng)常需要在mounted鉤子加載頁面數(shù)據(jù),為了避免浪費(fèi),先進(jìn)行判斷是比較好的。
和常用方法相比,簡(jiǎn)單方法是有額外開銷的,主要在于需要完全加載路由,同時(shí)在加載頁面后進(jìn)行了一次判斷。不過從寫代碼的角度來說,似乎邏輯上更節(jié)約,因?yàn)椴挥昧硗鈱懸粋€(gè)集中進(jìn)行權(quán)限控制的文件了,至于每個(gè)頁面的權(quán)限判斷,那是本來在菜單欄就要做的事情,延伸到不同頁面也不算什么負(fù)擔(dān)。
會(huì)不會(huì)有什么副作用呢?暫時(shí)來看似乎是沒有的,如果在mounted最開始就進(jìn)行頁面權(quán)限判斷,也不會(huì)有加載越權(quán)數(shù)據(jù)的問題,況且數(shù)據(jù)權(quán)限是后端需要單獨(dú)判斷的,不應(yīng)該讓前端去擔(dān)心。
關(guān)于“vue-router中如何實(shí)現(xiàn)權(quán)限控制”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。