React-Router是React项目中处理路由的库。

1. HashRouter

通过hashchange监听路由的变化,通过window.location.hash赋值触发监听的变化。

本质是一个react中的context对象,向下传参,传递参数有三种:

1. location

有四个属性:state, pathname, search, hash

state: 可以用来在路由中传递参数

pathname:  指定路由

2. history

主要有两个方法:

push: 可以实现跳转路由

// 传递对象
this.props.history.push({pathname: url, state: xxx})
// 传递路由
this.props.history.push(url)

3.match

通过该字段可以知道当前组件的路由是否和地址栏中路由相同。

应用:

实现单击后菜单呈现选中状态
import React, { Component } from 'react'
import { Route, Link } from '../react-router-dom'; export default function ({to, exact, ...rest}) {
// 实现单击后链接呈现选中状态
return (
<Route
path={to}
exact={exact}
children={(props) => {
return <Link to={to} className={props.match ? 'active' : ''}>{rest.children}</Link>
}}
/>
)
}

2.BrowserRouter

通过onpopstate事件监听通过点击前进后退/调用back()等方法的操作。通过改写pushState方法,监听页面中路由的变化。

其他和HashChange基本相同

3. Route

用于渲染指定路由的组件。children属性时,可以不指定路由。

用于匹配路由: path, exact

path: 指定路由

exact: 严格匹配

有三个属性用于渲染组件:

1. component

当path值匹配时,渲染component中的组件

2.render

当path匹配时,可以自定义渲染逻辑。相当于React中的render props复用组件功能。

如:受保护路由的实现。

import React from 'react';
import Route from '../react-router-dom/Route';
import { Redirect } from '../react-router-dom'; export default function({component:Component, ...rest}) {
return (
<Route {...rest}
render={(props) => localStorage.getItem('login') ?
<Component {...props} />
: <Redirect to={{pathname: '/login', state: {from: props.location.pathname}}} />}
/>
)
}

3.children

无论路由是否匹配,都会渲染。

如: 菜单的选中状态

import React, { Component } from 'react'
import { Route, Link } from '../react-router-dom'; export default function ({to, exact, ...rest}) {
// 实现单击后链接呈现选中状态
return (
<Route
path={to}
exact={exact}
children={(props) => {
return <Link to={to} className={props.match ? 'active' : ''}>{rest.children}</Link>
}}
/>
)
}

4. Link

to属性有两种参数形式

1. 对象类型

<Link to={{pathname: url, state: {xx:xx}}}/>

2. 字符串

<Link to="/user">

5. Switch/Redirect

Switch(只匹配一个路由)和Redirect(前面的都不匹配时走这个路由)配合使用。

重定向方式有两种:

1)组件重定向: <Redirect />

2)方法重定向 this.props.history.push()

6. withRouter

对于非Route加载的组件,想要使用从Route中传递的history,location,match属性,使用该方法。

其本质是个高阶组件。

import React from 'react';
import Route from './Route'; export default function(WrappedComponent) {
return (props) => <Route component={WrappedComponent} />
}

7. Prompt

1. 属性

1. when

根据该属性进行路由的拦截。当为true时,弹出一个下confirm框。

2.message

用于显示拦截的信息, 本质是个函数。

2. 原理

基于history.push()和history.block()方法。

React-Router常见API的更多相关文章

  1. React Router API文档

    React Router API文档 一.<BrowserRouter> 使用HTML5历史记录API(pushState,replaceState和popstate事件)的<Rou ...

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

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

  3. [Web 前端] 你不知道的 React Router 4

    cp from https://segmentfault.com/a/1190000010718620 几个月前,React Router 4 发布,我能清晰地感觉到来自 Twitter 大家对新版本 ...

  4. [转] React Router 使用教程

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

  5. React Router基础使用

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

  6. React Router 使用教程

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

  7. React router动态加载组件-适配器模式的应用

    前言 本文讲述怎么实现动态加载组件,并借此阐述适配器模式. 一.普通路由例子 import Center from 'page/center'; import Data from 'page/data ...

  8. React Router教程

    React Router教程 React项目的可用的路由库是React-Router,当然这也是官方支持的.它也分为: react-router 核心组件 react-router-dom 应用于浏览 ...

  9. React Router 用法

    React Router 用法 一.DEMO import React from "react"; import { HashRouter as Router, Route, Li ...

  10. react router @4 和 vue路由 详解(全)

    react router @4 和 vue路由 本文大纲: 1.vue路由基础和使用 2.react-router @4用法 3.什么是包容性路由?什么是排他性路由? 4.react路由有两个重要的属 ...

随机推荐

  1. JS中,JSON 和 对象互转,数组和字符串的转换?

    JSON 与 J对象转化 要实现从对象转换为 JSON 字符串,使用 JSON.stringify() 方法: 如下: var json = JSON.stringify({a: 'Hello', b ...

  2. Haystack搜索框架

    1.什么是Haystack Haystack是django的开源全文搜索框架(全文检索不同于特定字段的模糊查询,使用全文检索的效率更高 ),该框架支持Solr,Elasticsearch,Whoosh ...

  3. 远程登录Linux系统(使用xshell),远程上传加载文件(使用Xftp)

    一.Xshell(远程登录Linux系统) 1.安装xshell 自己百度找安装包 2.连接登录 1.连接前提 需要Linux开启一个sshd的服务,监听22号端口,一般默认是开启的 查看是否开启: ...

  4. hadoop功能与用途

    1.hadoop是什么? 开源的分布式存储和分布式计算平台. 2.hadoop组成? HDFS:分布式文件存储系统,存储海量数据. Mapreduce:并行处理框架,实现任务分配和调度. 3.hado ...

  5. Linux 生成随机mac地址,并固化到本地

    前言: 将Mac地址随机化并固化到本地可以有效避免同一个网络内,mac地址冲突导致的网络阻塞问题. 以下是有关的方法: 1.使用$RANDOM和md5sum(嵌入式无需移植其他软件的优秀可选方案) M ...

  6. 转!!DBCP2 配置详解说明

    转自:https://www.cnblogs.com/diyunpeng/p/6980098.html 由于commons-dbcp所用的连接池出现版本升级,因此commons-dbcp2中的数据库池 ...

  7. 未能加载文件或程序集 Microsoft.ReportViewer.ProcessingObjectModel, Version=10.0.0.0

    写在前面 整理错误集.某一天在启动项目的时候,出现了未能加载文件或程序集 Microsoft.ReportViewer.ProcessingObjectModel, Version=10.0.0.0错 ...

  8. 关键字ref、out

    通常,变量作为参数进行传递时,不论在方法内进行了什么操作,其原始初始化的值都不会被影响: 例如: public void TestFun1() { ; TestFun2(arg); Console.W ...

  9. Assignment 2: UDP Pinger[课后作业]

    Computer Networking : A Top-Down Approach 的课后作业. 要求: 基于UDP协议,实现一个Pinger工具. 服务端代码已经提供了,自己实现客户端的代码. 完整 ...

  10. DOS命令_查询某个端口的占用情况并释放

    >netstat -aon | findstr “80″Proto   Local Address           Foreign Address         State         ...