高清不卡毛片免费观看_国产成人精品久久亚洲高清不卡_99riav国产在线观看_亚洲精品视频在线

vue-admin-template權限管理(vuetemplate admin)

本文主要介紹vue-admin-模板權限管理,下面一起看看vue-admin-模板權限管理相關資訊。
在vue-admin-template角色權限設置(1)中提到了如何根據用戶角色控制訪問,但是在項目的實際使用中發現了一些存在的問題。下面主要針對這些存在的問題進行修改和完善。
1頁面刷新后頭像等個人信息消失的原因:頁面登錄成功后,項目通過getinfo方法獲取個人信息并存儲在vuex中,但頁面刷新后,vuex中的數據會丟失。這是因為js代碼運行在內存中,代碼運行時的所有變量和函數也都存儲在內存中。刷新頁面后,之前應用的內存被釋放,腳本代碼被重新加載,變量被重新分配,所以這些數據如果要存儲的話,必須外部存儲。解決方案:獲取數據后,在存儲器中保存數據的副本。這里需要注意的是:盡量不要在localstorage中存儲過多的數據,否則會影響頁面加載性能。從 @/api/用戶 從 amp導入{ gettoken,settoken,removetoken };;@/utils/auth ;從 amp導入{ resetrouter };;@/路由器 const getdefaultstate == { return {//使用localstorag: g: local storage . getitem( ;姓名和名稱。;)刷新后還存在?json . parse(local storag: ; 、avatar: local storage . getitem( ;阿凡達 ) ?json . parse(local storag: ; 、rol: local storage . getitem( ;角色 ) ?json . parse(local storag:[]} }常量統計e = getdefaultstateconst mutations = { r:(state)= { object . assign(stat:(stat:(stat:(state,avatar)= { state . avatar = avatar } } const actions = {//用戶登錄登錄({ commit },userinfo) { const { username,password } = userinfo返回新的承諾((resolve,reject){ log in然后(response = { const { data } =響應提交( 設置令牌 ,data . token)settoken(data . token)resolve})。catch(error = { reject(error)} })},//獲取用戶信息getinfo({ commit,state }){ return new promise((resolve,reject) = { getinfo(state.token)。然后(response = { const { data } = response;如果(!數據){退貨拒絕( 驗證失敗,請重新登錄! )} const {name,roles,avatar } = data//在lo備份個人信息。本地存儲。;角色 ,json。stringify (roles))本地存儲。;角色 ,json。stringify (roles))本地存儲。;阿凡達 ,json。stringify(頭像))如果(!roles | | roles . length = 0){ reject( ;您不是有效身份! )}//在local storage if(roles . includes( ;商店經理 )){本地存儲。setitem( ;許可 ,json。stringify([ ;添加 , 編輯和刪除。;]);} else if(roles . includes( ;收銀員 )||角色. includes( ;技術員和技術員。;)||角色. includes( ;造型師 ){本地存儲。setitem( ;許可 ,json。stringify([]);}提交( set _ name ,name)提交( 設置角色 角色)提交( 設定_頭像 ,頭像)解析(數據)})。catch(error = { reject(error)} })},//用戶注銷注銷({ commit,state }){ return new promise((resolve,reject) = {logout (state。token)。然后(= { remove token//must remove token first reset router//記得清空localstorage。remove item( ;許可 ).localstorage.removeitem;姓名和名稱。;)local storage . remove item( ;角色 )local storage . remove item( ;阿凡達 )提交( 重置狀態 )resolve })。貓ch(error = { reject(error)} })},//移除令牌resettoken({ commit }){ return new promise(resolve = { remove token//必須先移除令牌//記得清除local storage . remove item( ;許可 )local storage . remove item( ;姓名和名稱。;)local storage . remove item( ;角色 )local storage . remove item( ;阿凡達 ).提交( 重置狀態 )resolve} } export default {namespac: true,state,mutations,actions}這樣刷新后vuex中的值依然存在~
2.頁面刷新后,動態路由無法跳轉到/。一方面,頁面刷新后對應的vuex的值失效,另一方面,即使該值仍然有效,但是在addroutes動態添加路由之前,從靜態找到頁面,導致一直跳轉到404。解決方案:路線可以存儲在localstorage中。因為之前已經持久化了角色,所以可以在路由預保護中直接處理刷新情況。主要思想是在路由中加入動態路由表后,404路由也是動態加入的!需要注意的是,多次調用router.addroutes方重復添加路由,并警告路由名重復,可以重新打包一個方法。將router/index.js中的addroutes方法重新打包//解決路由名重復的問題。$ add routes = params = { router . match: router.options.routes//key代碼})。matcherrouter . add routes(params);};刪除*查找404 { path : ;* ,redirect : ;/404 ;,hidden: true}在路由器/index.js的靜態路由中在rc/permission.js中,刷新情況在router.before each (async (to,from,next) = { //啟動進度條nprogress.start //設置頁面標題document . title = get page title(to . meta . title)//判斷用戶是否已經登錄const hastoken = gettokenif(hastoken){ if(to . path = = = ;/登錄 ){ //如果登錄了,下一步重定向到首頁({ path : ;/ ;}) nprogress。done} else {//添加routes后第一次訪問添加的路由時,屏幕會是空白的,因為剛添加routes//后就立即訪問添加的路由,但是此時添加routes的執行還沒有結束,所以可以 找不到新添加的路由,導致屏幕空白。所以你需要再次訪問路線。//此時將使用next ({… to,replac: true })來確保在添加路由時,已經完全加載了動態添加的路由。//replac: true in next({…to,replac: true })只是一個設置信息,告訴vue在這個操作之后,你可以 t通過瀏覽器的后退按鈕返回到以前的路線。//通過getinfo判斷用戶是否獲得了權限角色const has roles = store . getters . roles store . getters . roles . length 0;if (hasroles) {//如果正在刷新if (store。狀態。許可。路線。length = = 0){//生成可訪問的路由const accessroutes = await store。派遣( 許可/生成路線。;,存儲。getters.roles)根據角色;//動態添加路由路由器呃。$ add routes(acc: ;* 、redirect: ;/404 ;,hidd:真})console . log(router . options . routes)下一個({...對,replac:真});} else { next} } else { try {//get userinfo//注意:角色必須是數組形式,比如[ ;行政及管理。;]或者,[ ;開發商 ,編輯 ] const {roles} = awaitstore。派遣( 用戶/getinfo ;)//根據角色生成可訪問的路由const access routes = awaitstore。派遣( 許可/生成路線。;,角色);//動態添加路由路由器。$ add routes(acc: ;* 、redirect: ;/404 ;,hidd:為真})//確保addroutes已完成//將其設置為真,以便導航不會留下歷史記錄({...對,replac:是真的});} catch (error) { //刪除令牌并轉到登錄頁面to重新登錄等待store.dispatch。;用戶/重置令牌 )message . error(error | | ;有錯誤 )下一個(`/登錄?redirect = $ { to . path } `)n progress . done} } } else {/*沒有標記*/ if (whitelist.indexof(to.path)!== -1) { //在免費登錄白名單中,直接進入next } else { //其他沒有訪問權限的頁面被重定向到登錄頁面。下一個(`/登錄?重定向= $ {到。path }`) nprogress。done} })it ;在這里刷新沒有問題!!結束了。
標簽:
路由頁面
了解更多vue-admin-模板權限管理相關內容請關注本站點。

常見的電腦主板故障代碼有哪些問題(常見的電腦主板故障代碼有哪些圖片)
可移動磁盤損壞如何修復,可移動磁盤壞了如何修復
qq空間中的訪問權限設置方法在哪里(qq空間的訪問權限怎么設置)
win7怎樣分區,win7如何分磁盤區域
win10將日歷嵌入桌面(win 10如何添加日歷在桌面)
vue-admin-template權限管理(vuetemplate admin)
microsoft手機怎么樣,微軟手機怎么樣
雷電模擬器下載沒反應(雷電模擬器下載了軟件打不開什么問題)
vivo手機怎么設置呼吸燈
傳奇手游變態版
雙固態硬盤的好處和壞處,固態硬盤的好處和壞處
二手電腦估價和成交價,回收二手電腦估價
SSD硬盤壽命,固態硬盤使用壽命一般多久
硬盤有問題死機(硬盤故障導致死機)
時空光年老照片修復免費版,老照片翻新修復免費軟件
適合新手的重裝win10教程步驟圖(適合新手的重裝win10教程步驟有哪些)
愛奇藝會員怎么共享賬號登錄(愛奇藝會員怎么共享賬號給別人用)
電腦桌面顏色發白(電腦顯示顏色泛白)
字體 win7(win7系統字體在哪個文件夾)
iphone怎么投屏到macbook上(蘋果如何投屏到macbook使用)
高清不卡毛片免费观看_国产成人精品久久亚洲高清不卡_99riav国产在线观看_亚洲精品视频在线

    亚洲麻豆视频| 国产精品v亚洲精品v日韩精品 | 亚洲欧美日韩中文在线制服| 国产区日韩欧美| 欧美凹凸一区二区三区视频| 午夜激情一区| 日韩香蕉视频| 在线观看国产日韩| 日韩视频免费| 一色屋精品视频在线观看网站| 国产精品99一区二区| 欧美成人网在线| 久久亚洲二区| 久久久一二三| 久久免费国产| 久久精品一区蜜桃臀影院| 亚洲午夜成aⅴ人片| 亚洲精品国精品久久99热| 在线不卡欧美| 韩国v欧美v日本v亚洲v| 国产日韩欧美中文| 国产欧美综合一区二区三区| 欧美日韩中文另类| 欧美日韩一区二区在线观看| 欧美高清视频www夜色资源网| 久久亚洲免费| 美日韩精品免费观看视频| 久久精品一区| 猛干欧美女孩| 欧美国产欧美综合 | 亚洲国产欧美一区二区三区丁香婷| 国产精品狼人久久影院观看方式| 欧美一级久久久久久久大片| 亚洲午夜女主播在线直播| 宅男噜噜噜66国产日韩在线观看| 99国产精品99久久久久久粉嫩| 亚洲精品国产日韩| 99精品免费视频| 亚洲免费在线观看| 欧美一区激情| 日韩一级不卡| 午夜精品www| 久久久女女女女999久久| 免费一区二区三区| 欧美日韩精品久久久| 国产精品免费在线| 韩国av一区二区三区在线观看| 狠狠色噜噜狠狠色综合久| 亚洲国产福利在线| 一区二区免费在线播放| 亚洲欧美日韩网| 久久久欧美一区二区| 欧美精品一区二区三区久久久竹菊| 欧美日韩一区三区四区| 国产日韩精品综合网站| 亚洲激情在线| 午夜精彩视频在线观看不卡| 亚洲精品中文字幕在线| 亚洲欧美久久久久一区二区三区| 久久久国际精品| 欧美深夜影院| 亚洲风情在线资源站| 亚洲午夜激情网页| 麻豆av一区二区三区| 国产精品美女午夜av| 亚洲黄色免费网站| 亚洲国产精品一区在线观看不卡| 99国产精品国产精品久久| 欧美在线一二三区| 欧美午夜不卡在线观看免费 | 伊人久久婷婷色综合98网| 99国产精品久久| 久久久中精品2020中文| 国产精品日韩高清| 一区二区三区导航| 欧美成人午夜视频| 激情一区二区| 欧美与黑人午夜性猛交久久久| 欧美伦理一区二区| 亚洲国产另类久久久精品极度| 亚洲欧美清纯在线制服| 欧美日本在线视频| 亚洲日本一区二区| 免费高清在线一区| 激情综合色综合久久| 欧美一区二区在线看| 国产精品一区二区久久国产| 日韩午夜激情电影| 欧美伦理影院| 夜夜躁日日躁狠狠久久88av| 欧美激情综合亚洲一二区| 亚洲国产成人tv| 久久综合国产精品| 激情五月***国产精品| 久久精品99无色码中文字幕 | 国产午夜精品久久久久久久| 亚洲一区二区三区精品视频| 欧美三级电影一区| 亚洲影院色在线观看免费| 欧美日韩在线三区| 中国成人黄色视屏| 欧美日韩在线电影| 亚洲少妇中出一区| 国产精品私拍pans大尺度在线| 一本色道久久综合狠狠躁篇的优点 | 久久国产精品网站| 国内精品久久久久影院 日本资源| 亚洲综合精品| 国产午夜精品美女毛片视频| 久久国产主播精品| 亚洲国产成人91精品| 欧美精品福利在线| 亚洲夜间福利| 国产亚洲亚洲| 欧美成人免费全部| 一区二区三区免费看| 国产精品一区二区久久国产| 欧美一区二区三区视频在线观看| 国产一区二区在线免费观看| 欧美gay视频| 亚洲天堂av在线免费| 国产伦精品一区二区三区在线观看 | 亚洲第一天堂无码专区| 欧美日韩p片| 欧美在线精品一区| 亚洲国产影院| 国产精品久久久久久久久动漫| 久久国产精品久久w女人spa| 亚洲国产成人久久| 欧美性大战久久久久久久蜜臀| 性欧美18~19sex高清播放| 亚洲高清久久网| 国产精品日日摸夜夜添夜夜av| 久久久精品一区| 一区二区激情| 在线播放国产一区中文字幕剧情欧美| 欧美精品入口| 久久亚洲综合色一区二区三区| 夜夜爽www精品| 亚洲国产精品va在线看黑人| 国产精品午夜国产小视频| 欧美国产日韩在线观看| 欧美影院一区| 中文一区字幕| 亚洲精品视频免费| 一色屋精品亚洲香蕉网站| 国产精品男gay被猛男狂揉视频| 媚黑女一区二区| 欧美一区二区视频观看视频| 最新精品在线| 在线观看精品视频| 国产亚洲精品自拍| 国产精品理论片| 国产精品盗摄一区二区三区| 欧美激情第8页| 美女图片一区二区| 欧美淫片网站| 欧美亚洲免费电影| 亚洲女人小视频在线观看| 亚洲精品社区| 亚洲美女毛片| 日韩亚洲国产精品| 亚洲欧洲日产国产网站| 在线观看视频一区二区| 国产综合色精品一区二区三区| 国产女主播在线一区二区| 国产精品成人一区二区| 欧美日韩国语| 欧美日韩精品综合| 欧美日韩另类国产亚洲欧美一级| 欧美国产日韩精品免费观看| 欧美大胆人体视频| 欧美大片91| 欧美激情精品久久久| 欧美成人伊人久久综合网| 欧美精品免费看| 欧美无砖砖区免费| 欧美性大战久久久久久久蜜臀| 欧美午夜不卡影院在线观看完整版免费 | 国产精品久久久一区二区三区| 欧美四级在线观看| 国产欧美一级| 伊人久久大香线| 亚洲欧洲日韩在线| 一区二区激情视频| 性欧美精品高清| 久久婷婷人人澡人人喊人人爽| 久热精品视频在线| 欧美日韩成人在线播放| 国产精品高清网站| 黑人巨大精品欧美黑白配亚洲 | 麻豆免费精品视频| 欧美日韩国产成人精品| 国产精品日韩专区| 1000部国产精品成人观看| 亚洲美女福利视频网站| 欧美在线短视频| 欧美成人久久| 国产精品日韩欧美一区二区三区 | 久久综合国产精品台湾中文娱乐网|