react-router v4注意事項

關(guān)于react-router的大部分資料可以從官方文檔中獲取

https://reacttraining.cn/web/guides/quick-start
這里寫幾點自己從v3 升級到v4時候出現(xiàn)的問題

1.代碼拆分:

官方上給的事例是自己實現(xiàn)一個bundle類塔猾,使用
bundle-loader?lazy!./Something 和webpack實現(xiàn)代碼拆分篙骡,這種方式在寫的時候略有麻煩,可以自己更改bundle類實現(xiàn)更簡單的丈甸。這里提供一個方法:
使用import LazyRoute from 'lazy-route'

  path: '/customer/detail/',
  breadcrumbName: '客戶管理/詳情',
  exact: true,
  render: (props) => <LazyRoute {...props} component={import('./containers/customer/Detail')}/>

這樣一個配置糯俗,就可以達(dá)到代碼拆分的效果且寫起來比較美觀

2.權(quán)限檢測:

權(quán)限檢測目前在項目中沒有找到一個好的方式去實現(xiàn)異步檢測,目前是將權(quán)限獲取到本地進(jìn)行同步檢測睦擂,在v4中和v3的方式完全不同得湘。v3 中路由有鉤子,而在v4中取消了該方法顿仇,總體我們可以自己封裝router類來實現(xiàn):

const PrivateRoute = ({component: Component, ...rest}) => (
  <Route {...rest} render={props => {
    return (
      api.isLogin() ?
        auth(props.match.path) ? (
          <Component {...props}/>
        ) : (
          <Redirect to={{
            pathname: '/permission-403',
            state: {from: props.location}
          }}/>
        ) : (
        <Redirect to={{
          pathname: '/login',
          state: {from: props.location}
        }}/>
      )
    )
  }}/>
);

export default PrivateRoute;

3.router 配置文件

v4中推薦配置文件配置路由忽刽,先將路由寫在一個配置文件中天揖,在需要展示的地方map出來

const routers = [{
  path: '/',
  breadcrumbName: "首頁/",
  exact: true,
  render: () => api.isLogin() ? <Redirect to="/home"/> : <Redirect to="/login"/>,
}, {
  path: '/home',
  exact: true,
  breadcrumbName: "首頁/",
  render: () => api.isHeadquarters() ? <OverView/> : <Home/>,
}, {
  path: '/customer/detail/',
  breadcrumbName: '客戶管理/詳情',
  exact: true,
  render: (props) => <LazyRoute {...props} component={import('./containers/customer/Detail')}/>
}, {
  path: '/customer/detail/:customerId',
  breadcrumbName: '客戶管理/詳情',
  exact: true,
  render: (props) => <LazyRoute {...props} component={import('./containers/customer/Detail')}/>
}]



routes.map((route, index) => (
                      <PrivateRoute
                        key={index}
                        path={route.path}
                        exact={route.exact}
                        component={route.render}
                      />

配置文件可以寫多個組件,在一個頁面我們可以顯示一個路由中的不同組件跪帝,比如sideBar breadcrumbName等等今膊。

配置文件不能寫空路由,即沒有定義組件的路由伞剑,這樣在渲染的時候因為匹配到了路由而不能渲染undefined組件報錯斑唬。

更多的信息可以見文檔。官方文檔寫的比較簡潔黎泣,從v3版本升級會遇到坑恕刘。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市抒倚,隨后出現(xiàn)的幾起案子褐着,更是在濱河造成了極大的恐慌,老刑警劉巖托呕,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件含蓉,死亡現(xiàn)場離奇詭異,居然都是意外死亡项郊,警方通過查閱死者的電腦和手機(jī)馅扣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來着降,“玉大人差油,你說我怎么就攤上這事∪味矗” “怎么了蓄喇?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長交掏。 經(jīng)常有香客問我公罕,道長,這世上最難降的妖魔是什么耀销? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任楼眷,我火速辦了婚禮,結(jié)果婚禮上熊尉,老公的妹妹穿的比我還像新娘罐柳。我一直安慰自己,他們只是感情好狰住,可當(dāng)我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布张吉。 她就那樣靜靜地躺著,像睡著了一般催植。 火紅的嫁衣襯著肌膚如雪肮蛹。 梳的紋絲不亂的頭發(fā)上勺择,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天,我揣著相機(jī)與錄音伦忠,去河邊找鬼省核。 笑死,一個胖子當(dāng)著我的面吹牛昆码,可吹牛的內(nèi)容都是我干的气忠。 我是一名探鬼主播,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼赋咽,長吁一口氣:“原來是場噩夢啊……” “哼旧噪!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起脓匿,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤淘钟,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后陪毡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體米母,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年缤骨,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片尺借。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡绊起,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出燎斩,到底是詐尸還是另有隱情虱歪,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布栅表,位于F島的核電站笋鄙,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏怪瓶。R本人自食惡果不足惜萧落,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望洗贰。 院中可真熱鬧找岖,春花似錦、人聲如沸敛滋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽绎晃。三九已至蜜唾,卻和暖如春杂曲,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背袁余。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工擎勘, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人泌霍。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓货抄,卻偏偏與公主長得像,于是被迫代替她去往敵國和親朱转。 傳聞我的和親對象是個殘疾皇子蟹地,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)藤为,斷路器怪与,智...
    卡卡羅2017閱讀 134,661評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,167評論 25 707
  • tags:開發(fā)隨筆 概述 和 Angular 那改朝換代般的升級相比,react技術(shù)棧一直以其穩(wěn)定的 API 而備...
    MarkNote閱讀 3,536評論 10 18
  • React Router v4 發(fā)布已經(jīng)有幾個月了缅疟,但好像并沒有得到太多人的青睞分别,大家(包括我們團(tuán)隊自己)還是習(xí)慣...
    艾特老干部閱讀 3,576評論 5 15
  • 列表 123 abe bcc 代碼塊 分割線 引用 標(biāo)題 標(biāo)題 標(biāo)題
    韓梅梅梅梅閱讀 128評論 0 0