鍍金池/ 問答/Linux  HTML/ react + dva 的路由跳轉(zhuǎn)問題

react + dva 的路由跳轉(zhuǎn)問題

我使用以下方法跳轉(zhuǎn):
先import { routerRedux } from 'dva/router';
如果在組件內(nèi)部用put(routerRedux.push('/login'))或者dispatch(routerRedux.push('/login'))都沒問題,正常跳轉(zhuǎn),但是我想在一個(gè)util里控制跳轉(zhuǎn),需求是:這個(gè)requestUtil發(fā)送請(qǐng)求后若收到后臺(tái)返回的自定義errorCode10101代表用戶未登錄或著token過期,此時(shí)跳轉(zhuǎn)到登錄界面.
那么問題來(lái)了,在組件外直接使用routerRedux.push('/login')無(wú)效,而組件外也沒有dispatch這個(gè)函數(shù),使用import { dispatch } from 'react-redux';得到的dispatch居然是個(gè)class而不是函數(shù),所以我該如何在一個(gè)util.js里面控制路由?
另外,在index.js里

const app = dva({
  onError(e, dispatch) {
    console.log(e.message);
  },
});

這個(gè)onError確實(shí)能收到我拋出的error,也可以用這個(gè)dispatch調(diào)用push,但是這個(gè)方法完了error沒有處理掉,不知在那個(gè)位置又重新拋出了,進(jìn)新頁(yè)面直接掛了,console顯示Uncaught Error.所以這個(gè)方法也不能用.
我該從什么地方拿到dispatch函數(shù)的引用?組件外(普通js代碼里)難道不能控制路由嗎?或者還有什么我不知道的方法?

回答
編輯回答
短嘆

已解決,dva文檔給的action方案不好用
詳詢https://segmentfault.com/n/13...

2018年5月12日 23:56