亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue-router中如何實現權限控制

發布時間:2022-05-05 18:23:22 來源:億速云 閱讀:240 作者:zzz 欄目:大數據

這篇文章主要介紹“vue-router中如何實現權限控制”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“vue-router中如何實現權限控制”文章能幫助大家解決問題。

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

  1. 有一種做法是直接在后端完成判斷,提供頁面列表和操作列表,在前端進行渲染,但這個方案并不優雅,前后端耦合度比較高。

  2. 比較常見的做法是把登錄頁面獨立在router之外,專門寫一個權限控制文件,在登錄之后根據用戶權限加載router,之后把權限作為參數傳入各種組件中,以控制元素的渲染。這個方法比較合理,沒有什么額外的開銷,只是需要獨立寫一個登錄頁面和權限控制文件比較麻煩一些,特別是對一些小項目而言。

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

  1. 菜單欄控制,根據權限渲染可以進入的頁面菜單;

  2. 操作按鈕權限控制,沒有操作權限的不予顯示;

  3. 如果有人通過直接點擊鏈接或輸入地址進入沒有權限的頁面,則進行攔截;

第一、第二個目標是容易實現的,把權限列表傳入對應組件,通過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鉤子加載頁面數據,為了避免浪費,先進行判斷是比較好的。

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

會不會有什么副作用呢?暫時來看似乎是沒有的,如果在mounted最開始就進行頁面權限判斷,也不會有加載越權數據的問題,況且數據權限是后端需要單獨判斷的,不應該讓前端去擔心。

關于“vue-router中如何實現權限控制”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阿克苏市| 忻城县| 武陟县| 新丰县| 通江县| 弥勒县| 白水县| 封开县| 如皋市| 阿荣旗| 连南| 綦江县| 许昌市| 塘沽区| 那曲县| 荣成市| 秦皇岛市| 司法| 五华县| 焉耆| 万山特区| 信丰县| 夏河县| 姜堰市| 隆回县| 应用必备| 天台县| 三亚市| 阳信县| 侯马市| 永城市| 桑植县| 都江堰市| 禄丰县| 榕江县| 石棉县| 拉孜县| 定结县| 江永县| 怀宁县| 多伦县|