国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

vue-router權限控制(簡單方式)

2024-05-06 15:28:23
字體:
來源:轉載
供稿:網友

在vue-router控制前端權限是常見需求:

    有一種做法是直接在后端完成判斷,提供頁面列表和操作列表,在前端進行渲染,但這個方案并不優雅,前后端耦合度比較高。 比較常見的做法是把登錄頁面獨立在router之外,專門寫一個權限控制文件,在登錄之后根據用戶權限加載router,之后把權限作為參數傳入各種組件中,以控制元素的渲染。這個方法比較合理,沒有什么額外的開銷,只是需要獨立寫一個登錄頁面和權限控制文件比較麻煩一些,特別是對一些小項目而言。

我們希望還有更簡單的方式。這個時候梳理一下需求,我們的主要目標是:

    菜單欄控制,根據權限渲染可以進入的頁面菜單; 操作按鈕權限控制,沒有操作權限的不予顯示; 如果有人通過直接點擊鏈接或輸入地址進入沒有權限的頁面,則進行攔截;

第一、第二個目標是容易實現的,把權限列表傳入對應組件,通過v-if判斷即可,需要解決的是越權頁面的攔截問題。在上面常見的做法中,為了實現攔截,單獨寫了一個登錄頁面,登錄之后再根據權限加載路由,這樣,沒有權限的路由根本不會加載,于是被導向404頁面。

那么,現在的問題是,怎么樣會有更簡單的方式?

顯然,如果我們不想單獨寫login頁面,那么router在登錄前就完成加載了。如果無法通過router自動將越權頁面導向404頁面,我們能做的,只能手動引導了。思路清楚了,實現起來就毫無壓力:

根據vue組件的生命周期,我們可以在mounted鉤子上進行權限判斷,如果通過props傳入的用戶權限列表沒有對應權限,就跳轉頁面到404:

mounted () {     if (!this.check_user_privilege (current_page)) {       this.$Message.error('權限不足');       this.$router.push('404');     } }

當然,事實上vue-router也提供了頁面跳轉時的鉤子方法,全局的有beforeEach、afterEach等,我們希望直接在組件內使用,則可以使用beforeRouteEnter方法,在進入頁面時進行判斷,比如:

beforeRouteEnter (to, from, next) {     next(vm => {       if (!vm.check_user_privilege (current_page)) {         vm.$Message.error('權限不足');         vm.$router.push('404');       }     })   },

具體可以參考[文檔]。

當然,就這個例子來說,用vue-router提供的鉤子還不如直接在mounted寫判斷條件,因為beforeRouteEnter方法中的next需要調用組件參數,是在mounted執行之后才執行的,而我們又經常需要在mounted鉤子加載頁面數據,為了避免浪費,先進行判斷是比較好的。

和常用方法相比,簡單方法是有額外開銷的,主要在于需要完全加載路由,同時在加載頁面后進行了一次判斷。不過從寫代碼的角度來說,似乎邏輯上更節約,因為不用另外寫一個集中進行權限控制的文件了,至于每個頁面的權限判斷,那是本來在菜單欄就要做的事情,延伸到不同頁面也不算什么負擔。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 偏关县| 定襄县| 黑龙江省| 观塘区| 临西县| 婺源县| 合肥市| 天水市| 凉山| 安泽县| 麦盖提县| 秀山| 竹北市| 泾源县| 哈巴河县| 仁布县| 荃湾区| 樟树市| 西城区| 镇康县| 新邵县| 本溪市| 长寿区| 开原市| 百色市| 栾城县| 北海市| 高平市| 辽宁省| 南雄市| 军事| 绍兴市| 长泰县| 浏阳市| 吴川市| 汶上县| 台东市| 平武县| 栾川县| 调兵山市| 黄骅市|