您的位置:首页 > 健康 > 美食 > React@16.x(39)路由v5.x(4)常见应用场景(1)- 受保护的页面

React@16.x(39)路由v5.x(4)常见应用场景(1)- 受保护的页面

2025/1/2 23:58:02 来源:https://blog.csdn.net/qq_40147756/article/details/139815774  浏览:    关键词:React@16.x(39)路由v5.x(4)常见应用场景(1)- 受保护的页面

目录

  • 1,实现
  • 2,知识点
    • 1,Route.children 和 Route.render
    • 2,保存跳转 login 之前的路由
    • 3,解构参数

现在有3个页面

  • Home 页面
  • Login 页面
  • Personal 页面(受保护,未登录无法进入)

1,实现

import { BrowserRouter as Router, Route, Switch, Link, Redirect } from "react-router-dom";
import ProtectedRoute from "./ProtectedRoute";
import loginInfo from "./loginInfo";function Login(props) {return (<><h1>登录页</h1><buttononClick={() => {loginInfo.login();// 跳转进入 login 之前,准备进入的页面(受保护页面)if (props.location.state) {props.history.replace(props.location.state);} else {props.history.replace("/");}}}>登录</button></>);
}
function Home() {return (<><h1>Home页</h1><Link to="/personal">个人中心</Link></>);
}function Personal() {return <h1>个人中心页</h1>;
}export default function App() {return (<Router><Switch><Route path="/login" component={Login}></Route><ProtectedRoute path="/personal" component={Personal}></ProtectedRoute><Route component={Home}></Route></Switch></Router>);
}

自定义的 ProtectedRoute 组件。使用方式和 Route 组件一样(参数一致),但需要登录才能进入。

import React from "react";
import { Route, Redirect } from "react-router-dom";
import loginInfo from "./loginInfo";export default function ProtectedRoute({ component: Comp, children, ...rest }) {return (<Route{...rest}render={(values) => {return loginInfo.isLogin ? <Comp /> : <Redirect to={{ pathname: "/login", state: values.location.pathname }}></Redirect>;}}></Route>);
}

2,知识点

1,Route.children 和 Route.render

官方文档

2个都是函数,参数是路由信息(history,location,match )。

区别render 只有当路由匹配时才会执行,children 无论是否匹配都会执行。

注意,上面的示例中因为使用了 Switch 组件,所以只会渲染一个路由组件,此时 renderchildren 表现是一致的。

2,保存跳转 login 之前的路由

一般当跳转受保护路由时,如果进入了 /login ,则需要保留之前的路由,方便登录后直接进入。

  • 方式1:将该路由路径作为 search 参数保留,之后跳转。
  • 方式2,将该路径路径保存在 state 中(push 的第2个参数),之后跳转。上面的例子用的该方式。

3,解构参数

如果传递的对象中,需要传递给其他组件,但有的属性不用传递。

此时,可以使用解构+剩余参数,参考上面的 ProtectedRoute 组件。


以上。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com