react-router基本使用

编程式导航(withRouter用法)

import {withRouter} from 'react-router-dom';

goBack(){
    this.props.history.goBack();
}  
goDetail(){
    this.props.history.push('/detail');
}  
goDetailWithParam(item){
    this.props.history.push({pathname : '/cart',state:{item}});
}
    
<span className="ico" onClick={this.goBack.bind(this)}>
    <i className="iconfont">&#xe501;</i>
</span>
//这里的item来自for循环的每一项
<li onClick={this.goDetailWithParam.bind(this,item)} key={encodeURI(item.imgUrl)}>

export default withRouter(Header);

引入withRouter之后,就可以使用编程式导航进行点击跳转, 需要注意的是export default的暴露如上面所写,如果结合redux使用,则暴露方式为: withRouter(connect(...)(MyComponent))

调用history的goBack方法会返回上一历史记录

调用history的push方法会跳转到目标页,如上面goDetail方法

跳转传参: push()可以接收一个对象参数,跳转之后,通过this.props.location.state接收

<BrowserRouter>
    <div className="App">
        <Switch>
            <Route exact path="/" component={Home}/>
            <Route exact path="/home" component={Home}/>
            <Route exact path="/playDeteil" component={PlayDetail}/>
            <Redirect to='/home'></Redirect>
        </Switch>
    </div>
</BrowserRouter>

按需加载

$ npm i -S react-loadable

1.在页面组件文件夹中新建loadable.js

import React from 'react';
import Loadable from 'react-loadable';
import Loading from './../../components/PageLoad';     // 过场组件
 
const LoadableComponent = Loadable({
  loader: () => import('./'),       // 当前文件下的组件(index.js)
  loading: Loading,
});
 
export default () => <LoadableComponent/>;

2.在路由js中引入component时,引入loadable.js

// 原始用法
import Home from './../views/home';
// loadable时引入方式
import Home from './../views/home/loadable';

3.如果跳转路由需要传参时,因为使用loadable组件包裹,所以需要使用withRouter让包裹的组件也能获取props。

import { withRouter } from 'react-router-dom';
...
export default withRouter(Component);

重要API一览

路由容器组件

  • BrowserRouter : 包裹整个应用

  • Router : 路由对应渲染组件,可嵌套

  • Link : 跳转专用

  • BrowserRouter:

浏览器自带的API,restful风格(需要后台做相应的调整);
  • HashRouter:
使用hash方式进行路由;
  • MemoryRouter:
在内存中管理history,地址栏不会变化。在reactNative中使用。
  • Route标签
- 该标签有三种渲染方式component、render、children(绝大多数情况使用component组件就好了);
- 三种渲染方式都会得到三个属性match、history、location;
- 渲染组件时,route props跟着一起渲染;
- children方式渲染会不管地址栏是否匹配都渲染一些内容,在这里加动画一时很常见的做法。
  • Link标签
- to: 后面可以接字符串,也可以跟对象(对象可以是动态地添加搜索的信息);
- replace: 当设置为true时,点击链接后将使用新地址替换掉访问历史记录里面的原地址。
  • NavLink标签
- 是的一个特定版本, 会在匹配上当前URL的时候会给已经渲染的元素添加样式参数;
- activeClassName: 当地址匹配时添加相应class;
- activeStyle: 当地址匹配时添加相应style;
- exact: 当地址完全匹配时,才生效;
- isActive: 添加额外逻辑判断是否生效。
  • Prompt标签
- when: when的属性值为true时启用防止转换;
- message: 后面可以跟简单的提示语,也可以跟函数,函数是有默认参数的。
  • Redirect标签
- 可以写在的render属性里面,也可以跟平级;
- to: 依旧是可以跟字符串或对象;
- push: 添加该属性时,地址不会被覆盖,而是添加一条新纪录;
- from: 重定向,与平级时。
  • match
- params: 通过解析URL中动态的部分获得的键值对;
- isExact: 当为true时,整个URL都需要匹配;
- path: 在需要嵌套的时候用到;
- url: 在需要嵌套的时候会用到;
- 获取方式: 以this.props.match方式。
import {
  BrowserRouter as Router, // 或者是HashRouter、MemoryRouter
  Route,   // 这是基本的路由块
  Link,    // 这是a标签
  Switch   // 这是监听空路由的,(/a, /b不使用时会先匹配'/')
  Redirect // 这是重定向
  Prompt   // 防止转换  
} from 'react-router-dom'

权限控制

  • 利用组件内的Redirect标签
const PrivateRoute = ({ component: Component, ...rest }) => (
  <Route {...rest} render={props => (
    fakeAuth.isAuthenticated ? (
      <Component {...props}/>
    ) : (
      <Redirect to={{
        pathname: '/login',
        state: { from: props.location }
      }}/>
    )
  )}/>
)

阻止离开当前路由

  • 在组件内部添加Prompt标签来进行权限控制
<Prompt
  when={isBlocking}
  message={location => (
    `你真的要跳转到 ${location.pathname}么?`
  )}
/>

过渡动画

  • 样式分别定义:.example-enter、.example-enter.example-enter-active、.example-leave、.example-leave.example-leave-active。

实例

<ReactCSSTransitionGroup
  transitionName="fade"
  transitionEnterTimeout={300}
  transitionLeaveTimeout={300}
>
  <!-- 这里和使用 ReactCSSTransitionGroup 没有区别,唯一需要注意的是要把你的地址(location)传入「Route」里使它可以在动画切换的时候匹配之前的地址。 -->
  <Route
    location={location}
    key={location.key}
    path="/:h/:s/:l"
    component={HSL}
  />
</ReactCSSTransitionGroup>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352