React开发中使用react-router-dom路由最新版本V5.1.2(一)基本跳转属性

react路由分为2个大的版本3.x及之前是个大的版本(react-router)、4.x之后又是一个大的版本(react-router-dom),下面我们来用5.1.2版本的基本使用方法

首先在我们的react项目中安装路由

npm install react-router-dom -S
或者
yarn add react-router-dom -S

基本的简单列子

import React from "react";
/**
 * BrowserRouter 相当于vue里的history
 * HashRouter 相当于vue里的hash url里带#号访问
* Switch 相当于vue里router-view
* Link 就是用来进行跳转的了 */ import { BrowserRouter as Router, Switch, Route, Link } from "react-router-dom"; import Home from './Home'; import About from './About'; import Dashboard from './Dashboard'; export default class Index extends React.Component { render() { return ( <Router> <div> <ul> <li> <Link to="/">Home</Link> </li> <li> <Link to="/about">About</Link> </li> <li> <Link to="/dashboard">Dashboard</Link> </li> </ul> <hr /> <Switch> <Route exact path="/"> <Home /> </Route> <Route path="/about"> <About /> </Route> <Route path="/dashboard"> <Dashboard /> </Route> </Switch> </div> </Router> ); } }

这时候在页面上就是看到,然后点击about

 

 

同时在switch里我们还可以这样写<Route exact path="/" component={Home}/>不用包裹

import React from "react";
import {
  HashRouter as Router,
  Switch,
  Route,
  Link
} from "react-router-dom";
import Home from './Home';
import About from './About';
import Dashboard from './Dashboard';
export default class Index extends React.Component {
  render() {
    return (
      <Router>
        <div>
          <ul>
            <li><Link to="/">Home</Link></li>
            <li><Link to="/about">About</Link></li>
            <li><Link to="/dashboard">Dashboard</Link></li>
          </ul>
          <hr />
          <Switch>
            <Route exact path="/" component={Home}/>
            <Route exact path="/about" component={About}/>
            <Route exact path="/dashboard" component={Dashboard}/>
          </Switch>
        </div>
      </Router>
    );
  }
}

这次用的HashRouter

 

 

 

 其实component意思就是需要返回一个虚拟dom

我们可以直接在里面返回简单的dom

<Route exact path="/dashboard" component={()=><div>这样也可以不</div>}/>

精准匹配

在上面的<Route>里我们看到有个exact属性,这个属性的意思就是精准匹配uri,意思就是uri必须和path是一样的才能匹配到对应的内容

我们把dashboard的exact去掉看一下结果===>

 

 

 /dashboard 和 /dashboard/qweq 都能跳转到,/about/qwer却匹配不到内容了

其实exact多个斜杠还是可以匹配到的,还有一个属性,strict叫完美匹配,多一个斜杠都不行

404和switch

switch我们在java或者js里都用过,意思就是只会匹配到一个,如果都匹配不到就会去default

<Switch>
            <Route exact path="/" component={Home}/>
            <Route exact path="/about" component={About}/>
            <Route exact path="/dashboard" component={()=><div>这样也可以不</div>}/>
            <Route component={()=><div>哦豁,404喽!</div>}/>
 </Switch>

  

 

 下一篇再说参数传递以及动态路由跳转

posted @ 2020-05-08 21:12  七度丢失的梦  阅读(5300)  评论(0编辑  收藏  举报