React 当中的路由

使用React构建的单页面应用,要想实现页面间的跳转,首先想到的就是使用路由。在React中,常用的有两个包可以实现这个需求,那就是react-router和react-router-dom。本文主要针对react-router-dom进行说明。

安装react-router-dom

  • npm install react-router-dom --save
  • yarn add react-router-dom // 本人喜欢的安装包方式 不了解的可以去看一下yarn官网

基本操作

首先我们新建两个组件(以下操作都是在react框架当中的操作 并不是原生react)

one 组件

import React, { Component } from 'react'

export default class One extends Component {
render() { return (
<div>
one
</div>
)
}
}

two 组件

import React, { Component } from 'react'

export default class Two extends Component {
render() {
return (
<div>
two
</div>
)
}
}

当我们在React当中使用路由的时候,必须在index.js这个入口文件引入路由

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import * as serviceWorker from './serviceWorker'; import { BrowserRouter as Router } from 'react-router-dom' //引入路由
ReactDOM.render(
<Router>
<App />
</Router>
, document.getElementById('root')); // If you want your app to work offline and load faster, you can change
// unregister() to register() below. Note this comes with some pitfalls.
// Learn more about service workers: https://bit.ly/CRA-PWA
serviceWorker.unregister();

浏览器有两种模式 历史记录模式(BrowserRouter) 哈希模式(HashRouter)

在这里我们使用的是历史记录模式

import { BrowserRouter as Router } from 'react-router-dom' //引入路由

因为 BrowserRouter太长了!! 所以我们用as给他起了一个别名Router。

通过Router包裹App组件我们就可以使用路由了,它同时也解决了路由传参的问题。这一步是必不可少的

在App.js当中

import React from 'react';
import './App.css';
import One from './component/one'
import Two from './component/two'
import { Route, Link, NavLink, Redirect, withRouter, Switch } from 'react-router-dom'
class App extends React.Component {
render() {
return (
<div className="App" > <Link to="/one">one组件</Link>
<Link to="/two">two组件</Link> <Route path='/one' component={One}></Route>
<Route path='/two' component={Two}></Route> </div>
);
}
} export default App;

第一步:我们需要引入One组件和Two组件

第二步:我们需要引入两个标签 Route 和 Link

第三步:路由跳转是根据路径来跳转的 这个步骤是由Route标签来实现的 path属性是目标地址 component是当路径是/one 的时候我们调用的组件名字

然后我们就可以实现路由切换

在路由切换的过程中也可以使用NavLink

import React from 'react';
import './App.css';
import One from './component/one'
import Two from './component/two'
import { Route, Link, NavLink, Redirect, withRouter, Switch } from 'react-router-dom'
class App extends React.Component {
change = () => {
this.props.history.push('two')
}
render() {
return (
<div className="App" > <NavLink to="/one">one组件</NavLink>
<NavLink to="/two">two组件</NavLink>
<Route path='/one' component={One}></Route>
<Route path='/two' component={Two}></Route> </div>
);
}
} export default App;

NavLink和Link无本质的区别 但是NavLink 比 Link 多了一个样式

我们可以通过 active类名来设置当前路由的样式

路由当中的重定向(重定向的意义一般是用来设置默认选中的组件)

设置重定向之前的效果

我们刚进入界面的时候 因为没有适用的路径,所以不会有任何组件的渲染

当我们设置了重定向的时候 我们默认访问的路径会变成/one

在路由当中 还有一个属性 精确匹配exact

import React from 'react';
import './App.css';
import One from './component/one'
import Two from './component/two'
import { Route, Link, NavLink, Redirect, withRouter, Switch } from 'react-router-dom'
class App extends React.Component {
change = () => {
this.props.history.push('two')
}
render() {
return (
<div className="App" > <NavLink to="/one/wen">one组件</NavLink>
<NavLink to="/two">two组件</NavLink> <Route path='/one/:name' component={One}></Route>
<Route path='/two' component={Two}></Route>
<Redirect from='/' to="/one" exact></Redirect>
</div>
);
}
} export default App;

我们还可以通过编程式导航实现路由切换

在我们的例子当中所使用的App组件并不是一个路由组件 他没有路由组件的三个重要属性 history location match

这个是App组件当中打印的this.props 并没有这三个属性

显而易见 App组件并不是一个路由组件 这个时候我们就需要用到 react-router-dom当中的withRouter,他可以将App组件变成一个路由组件这样有了history属性我们就可以实现编程式导航了

路由当中Switch 当有很多个匹配项的时候 他只会匹配第一个找到的

import React from 'react';
import './App.css';
import One from './component/one'
import Two from './component/two'
import { Route, Link, NavLink, Redirect, withRouter, Switch } from 'react-router-dom'
class App extends React.Component {
change = () => {
this.props.history.push('two')
}
render() {
return (
<div className="App" > <NavLink to="/one">one组件</NavLink>
<NavLink to="/two">two组件</NavLink>
{/* <button onClick={this.change} > 编程式导航到two组件</button> */}
<Switch>
<Route path='/one' component={One}></Route>
<Route path='/two' component={Two}></Route>
<Redirect from='/' to="/one" exact></Redirect>
</Switch>
</div>
);
}
} export default withRouter(App);

路由传参

通过params传值

优势 : 刷新地址栏,参数依然存在

缺点:只能传字符串,并且,如果传的值太多的话,url会变得长而丑陋。

import React from 'react';
import './App.css';
import One from './component/one'
import Two from './component/two'
import { Route, Link, NavLink, Redirect, withRouter, Switch } from 'react-router-dom'
class App extends React.Component {
change = () => {
this.props.history.push('two')
}
render() {
return (
<div className="App" > <NavLink to="/one/wen">one组件</NavLink>
<NavLink to="/two">two组件</NavLink>
{/* <button onClick={this.change} > 编程式导航到two组件</button> */}
<Switch>
<Route path='/one/:name' component={One}></Route>
<Route path='/two' component={Two}></Route>
<Redirect from='/' to="/one" exact></Redirect>
</Switch>
</div>
);
}
} export default withRouter(App);
 <Route path='/one/:name' component={One}></Route>  //这句话规定了参数的名字是name
<NavLink to="/one/wen">one组件</NavLink> // 这句话给传递的参数赋值 // 在one组件当中 我们可以用通过 this.props.match.params.name 获取参数

通过 to属性传值

优势:传参优雅,传递参数可传对象;

缺点:刷新地址栏,参数丢失

<Route path='/query' component={Query}/>
<Link to={{ path : ' /query' , query : { name : 'sunny' }}}>
this.props.history.push({pathname:"/query",query: { name : 'sunny' }});
读取参数用: this.props.location.query.name

React当中的路由使用的更多相关文章

  1. react router @4 和 vue路由 详解(五)react怎么通过路由传参

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 7.react怎么通过路由传参? a.通配符传参(刷新页面数据不丢失) //在定义路由的 ...

  2. react router @4 和 vue路由 详解(三)react如何在路由里面定义一个子路由

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 5.react如何在路由里面定义一个子路由?   a.引入在需要子路由的页面引入Rout ...

  3. react 当中重新渲染dom的方法

    有个upload 重复上传同名文件的需求,在网上找了很多解决方案都不好使,在react当中解决该问题其实很简单,其实无法上传同名文件 的原因是因为无法触发onChange事件,只需要刷新改dom就可以 ...

  4. 从 React Router 谈谈路由的那些事

    React Router 是专为 React 设计的路由解决方案,在使用 React 来开发 SPA (单页应用)项目时,都会需要路由功能,而 React Router 应该是目前使用率最高的. Re ...

  5. SAAS云平台搭建札记: (四) AntD For React使用react-router-dom路由接收不同参数页面不刷新的问题

    在.net开发员眼里,如果使用MVC,根据路由匹配原则,可以通过各种方式接收参数,比如 /Post/List/1, /Post/List/2,或者 /Post/List?id=1,/Post/List ...

  6. [react]react创建app,路由,mobx 全教程

    ​ 1.创建app, npx create-react-app my-app Cmd Copy 2.进入项目目录 cd my-app Cmd Copy 3.启用配置文件(默认是不开启配置文件的) ya ...

  7. React中的路由系统

    React中的路由系统 提起路由,首先想到的就是 ASPNET MVC 里面的路由系统--通过事先定义一组路由规则,程序运行时就能自动根据我们输入的URL来返回相对应的页面.前端中的路由与之类似,前端 ...

  8. react中的路由配置踩坑记

    react 路由配置中,如果根路由(/)匹配一个组件,另一个路由(/list)在进行匹配的时候也会匹配到根路由(/),即在 /list 页面展示的时候 / 页面总是展示在上方. 此时如果想进行严格匹配 ...

  9. react全家桶-路由

    /src目录下新增一个pages目录,用于存放渲染页面的组件 在/src/pages中新增一个Add.js文件 /src 下的index.js 路由:import React from 'react' ...

随机推荐

  1. profile(/etc/profile)和bash_profile的区别

    profile(/etc/profile)和bash_profile的区别 profile(/etc/profile),用于设置系统级的环境变量和启动程序,在这个文件下配置会对所有用户生效.当用户登录 ...

  2. bat 脚本定时删除备份文件

    删除 D:\yswbak 目录下rar类型 6天前的 文件 @echo off forfiles /p D:\yswbak /m *.rar /d -6 /c "cmd /c del @pa ...

  3. epic无法登陆怎么办【百分百解决】

    epic无法登陆怎么办(感谢吾爱破解吧www.52pjb.net)站长提供的文章教程以及解决思路,谢谢大佬,更详细的解决办法可以参考下他的网站解决的方法实例! epic登陆不上去怎么办?随着GTA5免 ...

  4. Java中的map集合顺序如何与添加顺序一样

    一般使用map用的最多的就是hashmap,但是hashmap里面的元素是不按添加顺序的,那么除了使用hashmap外,还有什么map接口的实现类可以用呢? 这里有2个,treeMap和linkedH ...

  5. springboot的坑

    No tests found for given includes:xxxx 找不到findOne()方法 可以用它的findById(id).orElse(null); 存在就会直接返回值,如果不存 ...

  6. python工业互联网应用实战2—从需求开始

    前言:随着国家工业2025战略的推进,工业互联网发展将会提速,将迎来一个新的发展时期,越来越多的企业开始逐步的把产线自动化,去年年底投产的小米亦庄的智能工厂就是一个热议的新闻.小米/华为智能工厂只能说 ...

  7. Web api配置填坑攻略

    最近开始使用web api,开发调试过程还算顺利,现在项目已经发布,网站已经部署,结果浏览过程出现问题(不出问题好像不正常吧……),做个note开始填坑. 1.1号坑 咋一开始就爆出另一个程序正在使用 ...

  8. 13.实战交付一套dubbo微服务到k8s集群(6)之交付dubbo服务的消费者集群到K8S

    构建dubbo-demo-consumer,可以使用和dubbo-demo-service的流水线来构建 1.登录jenkins构建dubbo-demo-consumer  2.填写构建dubbo-d ...

  9. 观察者模式(Observer Pattern)(二):HeadFirst中的气象站的实现

    1 观察者模式的原理,首先由一个主题,当主题发送变化的时候,通知该主题的订阅者 按照上面的分析我们来进行设计 1.抽象主题Subject public interface Subject { publ ...

  10. android 6.0 以上在doze模式精确定时

    public static void start12hAlarm() { int seconds = TIMERLENGTH; ECMLog.i_ecms(CLASS_TAG, " star ...