react---私有路由和权限判断(PrivateRoute + withRouter)

me

在这里插入图片描述

需要给<Route/> 套个<Switch></Switch>

PrivateRoute.jsx 私有路由

import React from "react";
import { Route, Redirect } from "react-router-dom";

function PrivateRoute(props) {
  const isLogin = localStorage.getItem("token") ? true : false;
  return isLogin ? (
    <Route
      path={props.path}
      render={() => <props.component></props.component>}
    ></Route>
  ) : (
    <Redirect to="/login" />
  );
}

export default PrivateRoute;

App.js

import React from "react";
// import { BrowserRouter as Router, Route, Link } from "react-router-dom";  不建议使用浏览器历史记录路由BrowserRouter
import {
  HashRouter as Router,
  Route,
  Link,
  // withRouter,
  BrowserRouter,
  Switch,
} from "react-router-dom";
import "./App.css";
import People from "./pages/People";
import { Button } from "antd";
import List from "./pages/List";
import About from "./pages/About";
import Login from "./pages/Login";
import PrivateRoute from "./pages/PrivateRoute";

const Home = (props) => {
  const { history } = props;
  return (
    <div>
      <h1>我是首页</h1>
      <Button onClick={() => history.push("/list")}>列表页</Button>
      <Button onClick={() => history.push("/about")}>关于我们</Button>
    </div>
  );
};

/* const About = (props) => {
  console.log(props);
  return <h1>有什么有什么要联系我们的吗,欢迎您哦</h1>;
};
const AboutPage = withRouter(About); */

function App() {
  return (
    <Router>
      <div className="App">
        <ul>
          <li>
            <Link to="/">首页</Link>
          </li>
          <li>
            <Link to="/list?t=ttt">列表</Link>
          </li>
          <li>
            <Link to="/people">People</Link>
          </li>
        </ul>
        <hr />
        <div className="content">
          <Switch>
            {/* 如果不加exact的话 每个页面都会有/那么每个页面都会有Home页这个内容 */}
            <Route path="/" exact component={Home}></Route>
            {/* <Route path="/list" component={List}></Route>
          <Route path="/people" component={People}></Route> 
          */}
            {/* 因为希望list、people这两个页面是在登陆之后才可以访问的,所以可以加上私有路由 也就是将Route改成PrivateRoute */}
            <PrivateRoute path="/list" component={List}></PrivateRoute>
            <PrivateRoute path="/people" component={People}></PrivateRoute>
            <Route path="/about" render={() => <About />}></Route>
            <Route path="/login" render={() => <Login />}></Route>
          </Switch>
        </div>
      </div>
    </Router>
  );
}

export default App;

List、Login、People这三个页面 需要使用withRouter
也就是 用到了PrivateRoute 和render路由形式的 都需要用到 withRouter
List.jsx

import React from "react";
import { withRouter } from "react-router-dom";

function List(props) {
  console.log(props);
   // 路由组件中会包含
  //    history
  //    location
  //    match
  // 此处可以使用new URLSearchParams获取当前查询条件
  //  使用模块qs也能获取查询条件
  const params = new URLSearchParams(props.location.search);
  console.log(params.get("t"));
  return (
    <div>
      <h1>我是一个列表页</h1>
    </div>
  );
}

export default withRouter(List);

teacher的

主要是这两个页面和自己的有所区别,其他的页面都一样
PrivateRoute.jsx

import React from "react";
import { Route, Redirect } from "react-router-dom";

// 此处定义一个私有路由 需要登录之后才能访问
function PrivateRoute({ children, ...rest }) {
  const isLogined = localStorage.getItem("token") ? true : false;
  // const rest = { ...props };
  // delete rest.children;
  // console.log(rest);
  console.group("私有路由判断");
  console.log(isLogined);
  console.groupEnd();
  return (
    <Route
      {...rest}
      render={() => (isLogined ? children : <Redirect to="/login" />)}
    />
  );
}

export default PrivateRoute;

App.js

import React from "react";
import {
  HashRouter as Router,
  Route,
  Link,
  NavLink,
  Switch,
} from "react-router-dom";
import { Button } from "antd";
import List from "./components/List";
import "./App.css";
import People from "./components/People";
import About from "./pages/About";
import PrivateRoute from "./components/PrivateRoute";
import Login from "./pages/Login";

const Home = (props) => {
  const { history } = props;
  return (
    <div>
      <h1>首页</h1>
      <Button
        onClick={() => {
          // 使用编程式跳转
          history.push("/list");
        }}
      >
        列表页
      </Button>
      <Button
        onClick={() => {
          // 使用编程式跳转
          history.push("/about");
        }}
      >
        关于我们
      </Button>
    </div>
  );
};

// const About = (props) => {
//   console.log(props);
//   return <h1>About us</h1>;
// };

// // 此处为高阶组件
// //  其实就是js中的高阶函数
// //  withRouter是一个函数,接收一个组件作为参数,为组件添加一些路由属性信息
// const AboutPage = withRouter(About);

function App() {
  return (
    <Router>
      <div className="App">
        <ul>
          <li>
            <NavLink exact to="/" isActive={() => true}>
              首页
            </NavLink>
          </li>
          <li>
            <NavLink to="/list?t=cart">列表</NavLink>
          </li>
          <li>
            <NavLink to="/p/oooo">People</NavLink>
          </li>
        </ul>
        <hr />

        {/* Route是一个组件 */}
        <div className="container">
          {/* Switch 只会匹配一个路由内容 ,PrivateRoute就可以用了,如果不加Switch,所有的就会都走一遍而产生冲突导致报错*/}
          <Switch>
            <Route path="/login" render={() => <Login />} />
            {/* exact 表示完全匹配 */}
            <Route path="/" exact component={Home} />
            <PrivateRoute path="/list">
              <List />
            </PrivateRoute>
            <PrivateRoute path="/p/:o">
              <People />
            </PrivateRoute>
            {/* render方式渲染组件,没有直接使用component指定组件
              这时候在路由对应的组件中没有history和location等路由的属性信息
          */}
            <Route path="/about" render={() => <About />} />
          </Switch>
        </div>
      </div>
    </Router>
  );
}

export default App;

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要添加路由,首先需要在react-router-dom v6中导入BrowserRouter和Routes组件。然后在Routes组件中添加Route组件,并指定path和component属性,用于指定路由路径和对应的组件。例如: ``` import { BrowserRouter, Routes, Route } from 'react-router-dom'; import Home from './components/Home'; import About from './components/About'; function App() { return ( <BrowserRouter> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> </Routes> </BrowserRouter> ); } ``` 在上面的示例中,当用户访问根路径时,会渲染Home组件,当访问/about路径时,会渲染About组件。需要注意的是,在v6中,使用element属性来指定要渲染的组件。 ### 回答2: 在使用React的项目中添加React Router Dom V6的路由非常简单。首先,确保项目中已经安装了ReactReact Router Dom V6的依赖。 然后,在项目的入口文件中,导入`BrowserRouter`组件,并在`ReactDOM.render`方法中将根组件包装在`<BrowserRouter></BrowserRouter>`标签中。 接下来,在根组件中,导入`Routes`和`Route`组件,分别用于定义路由规则和具体的路由路径。 使用`Routes`组件,可以在其内部使用多个`Route`组件来定义不同的路由。每个`Route`都包含两个属性:`path`和`element`。`path`表示路由的路径,`element`表示对应的组件。 通过这种方式,可以轻松地添加不同路径的路由。例如,可以创建一个`Home`组件,并在路由中添加`path="/" element={<Home />}`。这样,当用户访问根路径时,将加载`Home`组件。 除了基本的路径匹配,React Router Dom V6还引入了`<Switch>`组件用于路由的排他性匹配。在`Switch`组件内部,可以使用`<Route>`组件来定义不同的路由。当匹配到第一个路由后,就不会继续匹配后面的路由。 此外,React Router Dom V6还提供了一些其他的组件和钩子,如`<Link>`组件用于创建链接,`useNavigate`钩子用于进行编程方式的导航等。 总结起来,通过使用React Router Dom V6的`<Routes>`和`<Route>`组件,可以轻松地添加路由路径和对应的组件。并且,通过`<Switch>`组件可以实现路由的排他性匹配。在需要进行导航操作时,可以使用`<Link>`组件或`useNavigate`钩子。 ### 回答3: 在 React 中使用 react-router-dom v6 添加路由非常简单。以下是一个简单的演示: 首先,确保已经安装了 react-router-dom v6: ```shell npm install react-router-dom@next ``` 然后,在你的 App.js(或其他根组件)中导入所需的库和组件: ```jsx import React from 'react'; import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'; import Home from './Home'; import About from './About'; import NotFound from './NotFound'; const App = () => { return ( <Router> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="*" element={<NotFound />} /> </Routes> </Router> ); }; export default App; ``` 这里我们使用了 `<BrowserRouter>` 组件来为应用程序提供路由功能,然后使用 `<Routes>` 和 `<Route>` 组件来设置路由规则。 在 `<Routes>` 中,我们可以使用 `<Route>` 组件来定义具体的路由路径和对应的组件。`<Route>` 组件的 `path` 属性用于定义路由路径,`element` 属性用于指定该路径对应的组件。 在上面的例子中,我们将根路径 `/` 对应的组件设置为 `Home` 组件,路径 `/about` 对应的组件设置为 `About` 组件,而路径 `*` 对应的组件设置为 `NotFound` 组件(即未匹配到任何路由时显示的组件)。 当我们访问应用程序的不同路径时,react-router-dom v6 会根据路径自动加载相应的组件进行渲染。 希望这个简单的例子能够帮助你理解如何使用 react-router-dom v6 添加路由

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值