介绍

react-router被分为以下几部分:

  • react-router是浏览器和原生应用中的通用部分。

  • react-router-dom是用于浏览器的。

  • react-router-native是用于原生应用的。

react-router是核心部分。react-router-dom提供了浏览器使用需要的定制组件。react-router-native则专门提供了在原生移动应用中需要用到的部分。

安装

开发web引用只需要安装react-router-dom

npm install react-router-dom --save

三个props

history

History是React Router的两大重要依赖之一,在不同的JavaScript环境中,history以多种形式实现了对于session历史的管理。

history对象通常会具有以下属性和方法:

  • length - number类型,表示history堆栈的数量。

  • action - string类型,表示当前的动作。比如popreplacepush

  • location - object类型,表示当前的位置。

  • push(path, [state]) - function类型,在history堆栈顶加入一个新的条目。

  • replace(path, [state]) - function类型,替换在history堆栈中的当前条目。

  • go(n) - function类型,将history堆栈中的指针向前移动n

  • goBack() - function类型,等同于go(-1)

  • goForward() - function类型,等同于go(1)

  • block(promt) - function类型,阻止跳转。

match

match对象包含了<Route path>如何与URL匹配的信息。match对象包含以下属性:

  • params - object类型,表示路径参数,通过解析URL中动态的部分获得的键值对。

  • isExact - 为true时,整个URL都需要匹配。

  • path - string类型,用来做匹配的路径格式。

  • url - string类型,URL匹配的部分。

获取match对象:

  • 在Route component中,以this.props.match方式。

  • 在Route render中,以({ match }) => ()方式。

  • 在Route children中,以({ match }) => ()方式。

location

location是指当前的位置,下一步的位置,或者之前所在的位置。location的属性:

  • pathname - string类型,URL路径。

  • search - string类型,URl中查询字符串。

  • hash - string类型,URL的hash分段。

  • state - string类型,表示location中的状态,只会出现在browser history和memory history的环境里。

获取location对象的方式:

  • 在Route component中,以this.props.location的方式获取。

  • 在Route render中,以({ location }) => ()的方式获取。

  • 在Route children中,以({ location }) => ()的方式获取。

  • 在withRouter中,以this.props.location的方式获取。

路由组件

Router

针对不同功能和平台,有集中不同的子类组件:

  • <BrowserRouter> 浏览器的路由组件

  • <HashRouter> URL格式为Hash路由组件

  • <MemoryRouter> 内存路由组件

  • <NativeRouter> Native的路由组件

  • <StaticRouter> 地址改变的静态路由组件

BrowserRouter组件

BrowserRouter主要用于浏览器中,也就是web应用中。当点击程序中的一个连接之后,BrowserRouter就会找出与这个URL匹配的Route,并将对应的组件渲染出来。BrowserRouter是用来管理组件的,应用程序的组件作为它的子组件而存在。

BrowserRouter组件提供的属性:

  • basename - string类型,路由器 的默认根路径。

  • forceRefresh - bool类型,在导航的过程中整个页面是否刷新。

  • getUserConfirmation - function类型,当导航需要确认时执行的函数。默认是:window.confirm

  • keylength - number类型,location.key的长度。默认是6。

  • children - node类型,渲染单一子组件。

HashRouter

HashRouter使用的URL的hash来保持UI和URL的同步。使用hash的方式记录导航历史不支持location.keylocation.state。跟BrowserRouter类似,也有basenamegetUserConfirmationchildren属性,而且是一样的。

MemoryRouter

主要用在ReactNative这种非浏览器的环境中,因此直接将URL的history保存在了内容中。StaticRouter主要用于服务器端渲染。

Route组件

<Route>组件是react router的最重要的组件,当location与Route的path匹配时渲染Route中的Component。如果多个Route匹配,那么这些Route的Component都会被渲染。

Route组件的属性:

  • path - 字符串类型,它的值就是用来匹配url的。

  • component - 它的值是一个组件,在path匹配成功之后会渲染这个组件。

  • exact - 指明这个路由是不是排他匹配。

  • strict - 指明路径只匹配以斜线结尾的路径。

可以代替component属性的属性:

  • render - function类型,Route会渲染这个function的返回值,可以添加一些副作用。

  • children - 即使没有匹配路径的时候,也总是会渲染。我们可以根据match参数来决定匹配的时候渲染什么,不匹配的时候渲染什么。

所有路由中指定的组件将被传入以下三个props:locationmatchhistory

Link组件

使用<Link>可以在React应用的不同页面之间跳转,只会加载页面里和当前url可以匹配的部分。<Link>组件需要用到to属性,用来指明目标组件的地址,地址可以是一个字符串,也可以是一个location对象。

replace属性设置为true时,点击链接后将使用新地址替换掉访问历史记录里面的原地址。设置为false时,点击链接后将在原有访问历史的基础上添加一个新纪录。

NavLink是一个特殊的Link,可以使用activeClassName来设置Link被选中时被附加的class,使用activeStyle来配置被选中时应用的样式。exact属性要求路径完全匹配才会附加class和style。

Redirect组件

当这个组件被渲染时,location会被重写为Redirect的to制定到新location。它的一个用途是登陆重定向,比如用户在点击登录按钮并通过验证之后,将页面跳转到个人主页。

Switch组件

渲染匹配地址(location)的第一个<Route>或者<Redirect>。相反的,每一个包含匹配地址的(location)的<Route>都会被渲染。

React-router使用的更多相关文章

  1. [Redux] Filtering Redux State with React Router Params

    We will learn how adding React Router shifts the balance of responsibilities, and how the components ...

  2. [转] React Router 使用教程

    PS:react-route就是一个决定生成什么父子关系的组件,一般和layout结合起来,保证layout不行,内部的子html进行跳转 你会发现,它不是一个库,也不是一个框架,而是一个庞大的体系. ...

  3. [Redux] Navigating with React Router <Link>

    We will learn how to change the address bar using a component from React Router. In Root.js: We need ...

  4. [Redux] Adding React Router to the Project

    We will learn how to add React Router to a Redux project and make it render our root component. Inst ...

  5. React Router基础使用

    React是个技术栈,单单使用React很难构建复杂的Web应用程序,很多情况下我们需要引入其他相关的技术 React Router是React的路由库,保持相关页面部件与URL间的同步 下面就来简单 ...

  6. 最新的chart 聊天功能( webpack2 + react + router + redux + scss + nodejs + express + mysql + es6/7)

    请表明转载链接: 我是一个喜欢捣腾的人,没事总喜欢学点新东西,可能现在用不到,但是不保证下一刻用不到. 我一直从事的是依赖angular.js 的web开发,但是我怎么能一直用它呢?看看最近火的一塌糊 ...

  7. react router 4.0以上的路由应用

    thead>tr>th{padding:8px;line-height:1.4285714;border-top:1px solid #ddd}.table>thead>tr& ...

  8. React Router 使用教程

    一.基本用法 React Router 安装命令如下. $ npm install -S react-router 使用时,路由器Router就是React的一个组件. import { Router ...

  9. 关于react router 4 的小实践

    详细代码栗子:https://github.com/wayaha/react-dom-CY clone然后 npm install npm start 分割线 1.这个项目使用create-react ...

  10. React Router 4.x 开发,这些雷区我们都帮你踩过了

    前言 在前端框架层出不穷的今天,React 以其虚拟 DOM .组件化开发思想等特性迅速占据了主流位置,成为前端开发工程师热衷的 Javascript 库.作为 React 体系中的重要组成部分:Re ...

随机推荐

  1. ABAP里SELECT的用法汇总(转)

    通常使用Open SQL的数据查询语句SELECT将数据库条目选择到内存.一.SELECT语句:1)SELECT用于确定读取数据表中的哪些字段:2)FROM子句用于确定从哪些内表或者视图中读取数据:3 ...

  2. centos安装go环境

    centos安装go环境 1,下载合适的go安装包 https://studygolang.com/dl 2 上传到 centos服务器的 /usr/local下然后解压 3.设置go的环境变量    ...

  3. AlertDialog创建对话框的测试

    AlertDialog的功能是非常强大的,它可以创建各种对话框,它的结构分为:图标区.标题区.内容区.按钮区共四个区域.以这样的思路区创建AlertDialog是非常简单的. 创建AlertDialo ...

  4. 利用 OpenCC 工具进行文字的简繁转换

    前言 近日在公司遇到一个需求,因为准备要推出海外版产品,所以需要将所有的简体文字转换为繁体文字.一开始是改了表面的文字,但是后面发现很多提示语也需要去改,所以找了一个工具去对所有 .m 文件进行批量文 ...

  5. 分析Android APK-砸壳-Fdex2

    砸壳的工具千千万,但是FDex2 是最有能耐的,我尝试过各种壳,都是秒砸的.特别说明一下,360的壳,oncreated 方法还是空的,但是其他大部分内容还是有的,反正是可以参考一下的. 安装环境: ...

  6. 追踪SQL Server执行delete操作时候不同锁申请与释放的过程

    一直以为很了解sqlserver的加锁过程,在分析一些特殊情况下的死锁之后,尤其是并发单表操作发生的死锁,对于加解锁的过程,有了一些重新的认识,之前的知识还是有一些盲区在里面的.delete加锁与解锁 ...

  7. SQL Server之替换文本内容中的回车符和换行符

    UPDATE 表 SET 栏位A = REPLACE(栏位A, CHAR(10), '') UPDATE表 SET 栏位A = REPLACE(栏位A, CHAR(13), '')

  8. java执行-cp报错 error: could not load JDBC driver

    首先查看对应的 jar 包是否存在,然后看一下 Server (获取数据库驱动类的名称 driverClassName)是否正确 例如: java -

  9. Kali Linux上外网

    第一部分 攻击者杀链 第一章  走进Kali Linux 镜像准备:32位kali linxu 2019(之前下载好了,按书上的版本太低了要重新配置好多东西就用最新版了) , win XP 前两章照着 ...

  10. android 启动流程 相关 杂项记录

    Android原生流程 Init进程 主要流程及分支梳理 ueventd_main()watchdogd_main()主要流程a) 公共部分 增加PATH 环境变量初始化内核日志,打开/dev/kms ...