91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

马关县| 莒南县| 象州县| 崇阳县| 珲春市| 宁津县| 德州市| 五常市| 沙坪坝区| 漳州市| 青铜峡市| 闽清县| 武定县| 阿坝| 沐川县| 山丹县| 涞水县| 通山县| 新蔡县| 武定县| 南充市| 班玛县| 合水县| 洛南县| 乌什县| 澄城县| 离岛区| 新竹市| 武鸣县| 新巴尔虎左旗| 垦利县| 关岭| 孟津县| 巴里| 日土县| 孝昌县| 伊宁县| 扬州市| 日喀则市| 屏东县| 依兰县|