移动前端让前端飞前端开发那些事儿

React Router初识

2021-01-17  本文已影响0人  张中华

相关网址:

官方地址
React Router 中文文档
React-Router 入门教程
简书:React Router教程
阮一峰教程
GitHub地址

React Router是便于React开发单页应用进行路由管理的一个第三方库。它主要有以下几个部分组成:
<BrowserRouter> 、 <HashRouter>: 定义路由器,它们是两种不同的路由,选择一种即可
<Route> 、<Switch>: 定义路由
<Link>、<NavLink>、<Redirect>: 使用路由,进行跳转

大致知道了React Router的一个组成成分,接下来看看如何应用到项目中。
在创建好的React项目中引入react-router-dom

npm install react-router-dom
or
yarn add react-router-dom

那么接下来该如何使用呢?可以参照官网的快速开始https://reactrouter.com/web/guides/quick-start
接下来做两个实例快速了解下React Router的使用方式。

示例一:

这是一个常规的导航切换的功能,当然你也可以改变成左右两栏的布局。
github: https://github.com/956159241/ReactStudyDemo/tree/master/react-study-demo/src/router-demo1

import React from 'react';
import {BrowserRouter, Route, Link, Switch} from 'react-router-dom';

function Tab1() {
    return (<div>tab1</div>);
}

function Tab2() {
    return (<div>tab2</div>);
}

export default function RouterDemo1 () {
    return (
        <BrowserRouter>
            <div className='links'>
                <span style={{ margin:'5px'}}><Link to="/tab1">tab1</Link></span>
                <span style={{ margin:'5px'}}><Link to="/tab2">tab2</Link></span>
            </div>
            <Switch>
                <Route path='/tab1' component={Tab1} />
                <Route path='/tab2' component={Tab2} />
                <Route path='/' component={Tab1} />
            </Switch>
        </BrowserRouter>
    );

}

示例二:
很多时候我们需要设置二级导航,可能需要传递参数。
github: https://github.com/956159241/ReactStudyDemo/tree/master/react-study-demo/src/router-demo2

import React from "react";
import {
  BrowserRouter as Router,
  Switch,
  Route,
  Link,
  useParams,
  useRouteMatch
} from "react-router-dom";



export default function RouterDemo2() {
  return (
    <Router>
      <div>
        <ul>
            <li><Link to="/">首页</Link></li>
            <li><Link to="/itemlist">项目列表</Link></li>
        </ul>
        <Switch>
          <Route exact path="/" component={Home} />
          <Route path="/itemlist" component={ItemList} />
        </Switch>
      </div>
    </Router>
  );
}

function Home() {
  return (
    <div>
      <h2>首页</h2>
    </div>
  );
}

function ItemList() {
  let { path, url } = useRouteMatch();

  return (
    <div>
      <h2>项目列表</h2>
      <ul>
        <li>
          <Link to={`${url}/item1`}>项目一</Link>
        </li>
        <li>
          <Link to={`${url}/item2`}>项目二</Link>
        </li>
        <li>
          <Link to={`${url}/item3`}>项目三</Link>
        </li>
      </ul>

      <Switch>
        <Route exact path={path}>
          <h3>选择一个项目</h3>
        </Route>
        <Route path={`${path}/:itemId`} component={Item} />
      </Switch>
    </div>
  );
}

function Item() {
  let { itemId } = useParams();
  return (
    <div>
      <h3>{itemId}</h3>
    </div>
  );
}

上一篇 下一篇

猜你喜欢

热点阅读