React-Router 4 的新玩意儿

简介: 上一个项目用的还是 2.6.1,转眼的功夫 4.0 都发布了,API 变化实在有点大,2.X那套东西不顶用了,老老实实重新看一遍文档,其中有几点需要注意的,拿出来说一说。本文只讨论针对浏览器的应用,使用 react-router-dom(在react-router基础上封装了一些高级组件)进行说明。

上一个项目用的还是 2.6.1,转眼的功夫 4.0 都发布了,API 变化实在有点大,2.X那套东西不顶用了,老老实实重新看一遍文档,其中有几点需要注意的,拿出来说一说。

本文只讨论针对浏览器的应用,使用 react-router-dom(在react-router基础上封装了一些高级组件)进行说明。

  1. 关于BrowserRouter

如果按照原来的使用方式,就掉进第一个坑里了:history不合法。

用 react-router-dom 中的 <HashRouter>组件代替原来的 <Router> 组件就可以了。

这是之前2.X版本处理浏览器路由的方式,4.0版本中推荐另一个组件:<BrowserRouter >

换上<BrowserRouter >之后会出现 2 个问题:

如果你不是通过服务器启动应用,因为chrome自身的安全机制,在本地环境下根本不能用chrome玩。这个不关键,我本地测试换个浏览器还不行么,本地起个服务器也不麻烦。

关键问题,刷新就是404。原因很简单,BrowserRouter 和 HashRouter 完全不同,前者利用H5的 history 接口,前台路由就是后台收到的路由,你点到其他页面一刷新,得,根本没这个文件,服务器也很无辜,到底让我渲染个啥?后台也可以简单的解决这个问题:甭管你请求的啥地址,我先把入口文件扔给你。node处理方式如下(需要express):

app.get('*',(request,response)=>{

  response.sendFile(path.resolve(__dirname,'../index.html'))

})

 

启动node服务器,通过本机服务器访问,完美解决上面两个问题。

(<MemoryRouter> 和 <StaticRouter> 分别是非浏览器环境和服务器端渲染用的,在此不做讨论。)

  1. BrowserRouter 里可以存在各种标签。

原来用惯了2.X的同志们,看到新文档的例子可能会发现这个问题:Router里边不是只能有Route么,怎么什么都有。是的,4.0中 Router 里可以存在各种标签。

  1. 导航连接<NavLink>

看名字就是导航用的,主要用途就是区分激活的状态,激活时的样式。之前揉柔在Link里的。

  1. 只渲染第一个匹配的组件<Switch>

一个路由可能同时匹配多个路径,在<Switch>中,只渲染匹配的第一个,其他的放弃。之前这是Router的默认行为,4.0中为什么不默认了呢?答:可以将多个Route组合到页面中。想一想,如果你就是想同时渲染多个组件而不只是第一个呢?很欣慰看到我在2.X中吐槽的问题得到了解决。4.0版本给我最大的感觉就是:他让浏览器更灵活的去渲染页面。

  1. <Route>的渲染方法:

<Route component>

<Route render>

<Route children>

component和之前2.X的方法相同。

render可以传个函数避免创建新的React element(内联渲染时使用避免不必要的重载)。

children使用方式与render一致,只不过无论路由是否匹配都会被渲染。

exact属性为 true需要路由完全匹配时才渲染组件(之前也是默认行为)。

  1. 三个重要对象:history,location,match

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

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

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

History match的获取方式类似。

相关文章
|
11月前
|
前端开发 开发者
Umi 4 特性 02:React Router 6 和新路由
Umi 4 特性 02:React Router 6 和新路由
784 0
|
2月前
|
前端开发 JavaScript API
介绍一下React Router的工作原理。
介绍一下React Router的工作原理。
31 5
|
3月前
|
前端开发 JavaScript API
React Router v6 完全指南(下)
React Router v6 完全指南(下)
|
3月前
|
存储 资源调度 前端开发
React Router v6 完全指南(上)
React Router v6 完全指南(上)
150 0
|
5月前
|
存储 前端开发 JavaScript
React Router,常用API有哪些?
React Router,常用API有哪些?
43 0
|
8月前
|
前端开发
【react 中router v6 与 v5 区别】
【react 中router v6 与 v5 区别】
|
10月前
|
前端开发
React全家桶建站教程-Router #6
React全家桶建站教程-Router #6
52 0
|
10月前
|
存储 前端开发 安全
在 React Router 中使用 JWT
本篇文章将探讨 JWT 身份校验与 React 和 React-router 的无缝集成。 我们还将学习如何处理公共路由、受校验保护路由,以及如何利用 axios 库通过身份验证令牌发出 API 请求
138 0
在 React Router 中使用 JWT
|
前端开发 网络架构
React学习笔记(七) React Router
React学习笔记(七) React Router
72 0
|
前端开发 网络架构 UED
React Router
React Router
84 0