第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在dva.js中如何攔截路由(做登錄認證),沒有類似vue中的beforeEach鉤子函數(shù)

在dva.js中如何攔截路由(做登錄認證),沒有類似vue中的beforeEach鉤子函數(shù)

一只萌萌小番薯 2019-05-12 13:07:11
現(xiàn)在公司的后臺系統(tǒng)使用螞蟻金服的dva.js,基于react+redux的封裝,使用的是dva-cli,現(xiàn)在要做登錄認證。react-router-dom中好像沒有類似vue中的beforeEach鉤子函數(shù),可以攔截路由。importReactfrom'react';import{Router,Route,Switch,Redirect}from'dva/router';importrouterListfrom'./common/routerList';importError404from'./routes/Error/Error404';exportdefaultfunctionRouterConfig({history,app}){consttoken=app._store.getState().user.token;console.log('routergettoken:',token);constRouters=routerList.map((item,index)=>{return{if(item.noAuth){//如果是不用登錄就可訪問的頁面,直接返回return;}else{if(token){return;}else{return}}}}/>});return({Routers}()}/>);}這是我做的路由攔截,但是只有在第一次進入頁面,或者頁面刷新后才會有效果,應該怎么改呢然后登錄的時候,使用this.props.history.push()或者this.props.history.replace()也不能跳轉到首頁this.props.dispatch({type:'user/saveUserInfo',payload:{userId,nickName,headImageUrl,userName}});this.props.dispatch({type:'user/saveToken',payload:token});letRedirectUrl=this.props.location.state?this.props.location.state.from.pathname:'/';console.log(RedirectUrl);this.props.history.replace(RedirectUrl);
查看完整描述

2 回答

?
胡說叔叔

TA貢獻1804條經(jīng)驗 獲得超8個贊

react-router4+在官方教程中給出了一個登錄認證的范例。
類似于vue的鉤子函數(shù)是沒有的,因為沒有靜態(tài)路由配置表的概念。主要思想還是通過認證組件包裹你的那些涉及到認證信息的頁面組件,在認證組件中實現(xiàn)登錄重定向/被包裹組件渲染的邏輯。
                            
查看完整回答
1 反對 回復 2019-05-12
  • 2 回答
  • 0 關注
  • 2014 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號