热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Reactrouter5.x使用总结

在Reactrouter中通常使用的组件有三种:路由组件(作为根组件):BrowserRouter(history模式)和HashRouter(hash模式)路径匹配组件:Rout

在 React router 中通常使用的组件有三种:



  • 路由组件(作为根组件): BrowserRouter(history模式) 和 HashRouter(hash模式)

  • 路径匹配组件: Route 和 Switch

  • 导航组件: Link 和 NavLink

关于路由组件,如果我们的应用有服务器响应web的请求,建议使用组件; 如果使用静态文件服务器,建议使用组件。


1、安装:

cnpm i react-router react-router-dom -S

2、使用:

import React, { Component } from 'react'
import { BrowserRouter, Route, Link } from 'react-router-dom'
import ThisCollapse from '@/components/ThisCollapse'
import ThisProgress from '@/components/ThisProgress'
import ThisTable from '@/components/ThisTable'
export default class App extends Component {
render() {
return (







)
}
}


3、路由组件 BrowserRouter 和 HashRouter:

BrowserRouter(history模式) 和 HashRouter(hash模式)作为路由配置的最外层容器,是两种不同的模式,可根据需要选择。

hash 模式:

import React, { Component } from 'react'
import { HashRouter, Route, Link } from 'react-router-dom'
import ThisCollapse from '@/components/ThisCollapse'
import ThisProgress from '@/components/ThisProgress'
import ThisTable from '@/components/ThisTable'
export default class App extends Component {
render() {
return (







)
}
}

通过“http://localhost:8080/#/a” 即可直接访问组件ThisCollapse。

history 模式:

import React, { Component } from 'react'
import { BrowserRouter, Route, Link } from 'react-router-dom'
import ThisCollapse from '@/components/ThisCollapse'
import ThisProgress from '@/components/ThisProgress'
import ThisTable from '@/components/ThisTable'
export default class App extends Component {
render() {
return (







)
}
}

注意:当我们去访问localhost:8081/a这个地址的时候,webpack-dev-server会默认为你要访问服务器上的一个a页面。但我们的项目中只有一个index.html页面,并不存在list页面。所以它会提示你:Cannot GET /a(页面不存在)

在package.json中,我们可以使用webpack-dev-server中的 historyApiFallback 配置来解决此问题:

devServer: {
historyApiFallback: true
}

这样通过:“http://localhost:8080/a”可以直接访问组件ThisCollapse。


4、路径匹配组件: Route 和 Switch:

Route: 用来控制路径对应显示的组件

有以下几个参数:

4.1 path:指定路由跳转路径

4.2 exact: 精确匹配路由

4.3 component:路由对应的组件

import ThisCollapse from '@/components/ThisCollapse'
...

4.4 render: 通过写render函数返回具体的dom:

(

about
)}>

render 也可以直接返回 About 组件,像下面:

}>

但是,这样写的好处是,不仅可以通过 render 方法传递 props 属性,并且可以传递自定义属性:

{
return
}}>

然后,就可在 About 组件中获取 props 和 name 属性:

componentDidMount() {
console.log(this.props)
}
// this.props:
// history: {length: 9, action: "POP", location: {…}, createHref: ƒ, push: ƒ, …}
// location: {pathname: "/home", search: "", hash: "", state: undefined, key: "ad7bco"}
// match: {path: "/home", url: "/home", isExact: true, params: {…}}
// name: "cedric"

render 方法也可用来进行权限认证:

{
// isLogin 从 redux 中拿到, 判断用户是否登录
return isLogin ? :

请先登录

}}>

4.5 location: 将 与当前历史记录位置以外的位置相匹配,则此功能在路由过渡动效中非常有用

4.6 sensitive:是否区分路由大小写

4.7 strict: 是否配置路由后面的 '/'

Switch

渲染与该地址匹配的第一个子节点 或者

类似于选项卡,只是匹配到第一个路由后,就不再继续匹配:








此时,“http://localhost:8082/a”只能匹配到组件ThisCollapse。

所以,如果像下面这样:








当路由为/detail/1时,只会访问匹配组件detail, 所以需要在detail路由上加上exact:








 注意:如果路由 Route 外部包裹 Switch 时,路由匹配到对应的组件后,就不会继续渲染其他组件了。但是如果外部不包裹 Switch 时,所有路由组件会先渲染一遍,然后选择到匹配的路由进行显示。


5. 导航组件: Link 和 NavLink

Link 和 NavLink 都可以用来指定路由跳转,NavLink 的可选参数更多。

Link

两种配置方式:

通过字符串执行跳转路由


登录

通过对象指定跳转路由



  • pathname: 表示要链接到的路径的字符串。

  • search: 表示查询参数的字符串形式。

  • hash: 放入网址的 hash,例如 #a-hash。

  • state: 状态持续到 location。通常用于隐式传参(埋点),可以用来统计页面来源

pathname: '/login',
search: '?name=cedric',
hash: '#someHash',
state: { fromWechat: true }
}}>
登录

点击链接 进入 Login 页面后,就可以在this.props.location.state中看到 fromWechat: true:

NavLink

可以看做 一个特殊版本的 Link,当它与当前 URL 匹配时,为其渲染元素添加样式属性。


登录

to="/login"
activebold',
color: 'red'
}}
>
登录



  • exact: 如果为 true,则仅在位置完全匹配时才应用 active 的类/样式。

  • strict: 当为 true,要考虑位置是否匹配当前的URL时,pathname 尾部的斜线要考虑在内。

  • location 接收一个location对象,当url满足这个对象的条件才会跳转

  • isActive: 接收一个回调函数,只有当 active 状态变化时才能触发,如果返回false则跳转失败

const oddEvent = (match, location) => {
if (!match) {
return false
}
const eventID = parseInt(match.params.eventID)
return !isNaN(eventID) && eventID % 2 === 1
}
to="/login"
isActive={oddEvent}
>login


6. Redirect

将导航到一个新的地址。即重定向。






上面,当访问路由‘/’时,会直接重定向到‘/home’。

常在用户是否登录:

class Center extends PureComponent {
render() {
const { loginStatus } = this.props;
if (loginStatus) {
return (

个人中心

)
} else {
return
}
}
}

也可使用对象形式:

to={{
pathname: "/login",
search: "?utm=your+face",
state: { referrer: currentLocation }
}}
/>


 7. withRouter

withRouter 可以将一个非路由组件包裹为路由组件,使这个非路由组件也能访问到当前路由的match, location, history对象。

import { withRouter } from 'react-router-dom';
class Detail extends Component {
render() {
··· ···
}
}

const mapStateToProps = (state) => {
return {
··· ···
}
}
const mapDispatchToProps = (dispatch) => {
return {
··· ···
}
}

export default connect(mapStateToProps, mapDispatchToProps)(withRouter(Detail));


8. 编程式导航 - history 对象

例如,点击img进入登录页:

class Home extends PureComponent {
goHome = () => {
console.log(this.props);

this.props.history.push({
pathname: '/login',
state: {
identityId: 1
}
})
}
render() {
return (

)
}
}

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




  • length - (number 类型) history 堆栈的条目数

  • action - (string 类型) 当前的操作(PUSH, REPLACE, POP)

  • location - (object 类型) 当前的位置。location 会具有以下属性:

  • pathname - (string 类型) URL 路径

  • search - (string 类型) URL 中的查询字符串

  • hash - (string 类型) URL 的哈希片段

  • state - (object 类型) 提供给例如使用 push(path, state) 操作将 location 放入堆栈时的特定 location 状态。只在浏览器和内存历史中可用。

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

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

  • go(n) - (function 类型) 将 history 堆栈中的指针调整 n

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

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

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


注意,只有通过 Route 组件渲染的组件,才能在 this.props 上找到 history 对象

所以,如果想在路由组件的子组件中使用 history ,需要使用 withRouter 包裹:

import React, { PureComponent } from 'react';
import { withRouter } from 'react-router-dom';
class 子组件 extends PureComponent {
goHome = () => {
this.props.history.push('/home')
}
render() {
console.log(this.props)
return (

子组件

)
}
}
export default withRouter(子组件);


9. 路由过渡动画

import { TransitionGroup, CSSTransition } from "react-transition-group";
class App extends Component {
render() {
return (







{/* 最外部的不进行任何路由匹配,仅仅是用来传递 location */}

{
console.log(location);
return (

key={location.key}
classNames='fade'
timeout={300}
>






Not Found
} />



)
}}>





)
}
}

.fade-enter {
opacity: 0;
z-index: 1;
}
.fade-enter.fade-enter-active {
opacity: 1;
transition: opacity 300ms ease-in;
}


10. 打包部署的路由配置

项目执行npm run build后,将打包后的build文件当大 Nginx 配置中。

如果 react-router 路由 使用了 history 模式(即),那么在 Nginx 配置中必须加上:

location / {
··· ···
try_files $uri /index.html;
··· ···
}
}

如果 react-router 路由 使用了 hash 模式(即),那么在 Nginx 中不需要上面的配置。



推荐阅读
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • WebSocket与Socket.io的理解
    WebSocketprotocol是HTML5一种新的协议。它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送 ... [详细]
  • Hibernate延迟加载深入分析-集合属性的延迟加载策略
    本文深入分析了Hibernate延迟加载的机制,特别是集合属性的延迟加载策略。通过延迟加载,可以降低系统的内存开销,提高Hibernate的运行性能。对于集合属性,推荐使用延迟加载策略,即在系统需要使用集合属性时才从数据库装载关联的数据,避免一次加载所有集合属性导致性能下降。 ... [详细]
  • 本文讨论了将HashRouter改为Router后,页面全部变为空白页且没有报错的问题。作者提到了在实际部署中需要在服务端进行配置以避免刷新404的问题,并分享了route/index.js中hash模式的配置。文章还提到了在vueJs项目中遇到过类似的问题。 ... [详细]
  • loader资源模块加载器webpack资源模块加载webpack内部(内部loader)默认只会处理javascript文件,也就是说它会把打包过程中所有遇到的 ... [详细]
  • ①页面初始化----------收到客户端的请求,产生相应页面的Page对象,通过Page_Init事件进行page对象及其控件的初始化.②加载视图状态-------ViewSta ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 必须先赞下国人npm库作品:node-images(https:github.comzhangyuanweinode-images),封装了跨平台的C++逻辑,形成nodejsAP ... [详细]
author-avatar
红杏出墙的爱_408
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有