react路由
现代的前端应用大多都是 SPA(单页应用程序),也就是只有一个 HTML 页面的应用程序。因为它的用户体验更好、对服务器的压力更小,所以更受欢迎。为了有效的使用单个页面来管理原来多页面的功能,前端路由应运而生 前端路由是一套映射规则,在React中,是 URL路径 与 组件 的对应关系
react-router-dom
React实现页面路由的模块:react-router-dom
路由器组件:< HashRouter > < BrowserRouter >
HashRouter BrowserRouter hash 路由和 history 路由的区别: 原理不同: hash 路由是通过监听 hashChange 事件实现;history路由是通过 调用 history.pushState 方法 和监听 popState 事件实现 表现方式不同:hash 路由前面带 # ;history路由没有 history路由在页面刷新的时候可能会有白屏的情况;因为刷新后浏览器会向服务器发送这个地址的请求,但文件资源并不存在,会报404错误;需要后端做一个保底映射,所有的请求全部拦截到index.html上。 使用方式:
import { BrowserRouter as Router, Route, Switch, } from 'react-router-dom' import Home from '../containers/home' const BasicRouter = ( ) => ( < Router> < Switch> < Route exact path= "/" component= { Home} / > < / Switch> < / Router> ) export default BasicRouter
Route 标签:定义具体组件
< Route path= "/xx/xx" component= { 组件} > < / Route>
< Route path= "/xx/xx" element= { < 组件名/ > } / >
v5以及其他老版本: 当路由为 / 时,默认模糊匹配;这样可能会存在匹配到多个的问题 用 Switch 标签包裹之后:按顺序 自上而下 匹配 exact 属性可以设置为精准匹配 v6版本: 默认 精准匹配;匹配完整路径; 不需要Switch 标签、exact 属性 若要匹配某一部分,则在路径后面加 /* 可以将path 设置为 *,用于实现 404页面
Link 标签、NavLink标签
类似 a 标签,用于跳转 NavLink:可以设置激活状态的样式 老版本:可以通过 activeClassName 或 activeStyle 设置 v6:可以通关箭头函数 接收isActive
Navigate 组件
import { Navigate } from "react-router-dom" ; function A ( ) { return < Navigate to= "/b" / > ; } ` ` `
## useNavigate 编程式路由跳转
+ 可以通过 JS 代码完成路由跳转
+ useNavigate取代了原先版本中的useHistory
+ 可以直接传入要跳转的目标路由
` ` ` jsimport { useNavigate } from 'react-router-dom' ; function Foo ( ) { const navigate = useNavigate ( ) ; return ( < div onClick= { ( ) => navigate ( '/b' ) } > 跳转到/ b< / div> < div onClick= { ( ) => navigate ( 'a11' ) } > 跳转到/ a/ a1/ a11< / div> < div onClick= { ( ) => navigate ( '../a2' ) } > 跳转到/ a/ a2< / div> < div onClick= { ( ) => navigate ( - 1 ) } > 跳转到/ a< / div> ) }
动态路由参数
useParams 获取路径参数
在Route组件中的path属性中定义路径参数 在组件内通过useParams hook 访问路径参数
< BrowserRouter> < Routes> < Route path= "/foo/:id" element= { < Foo / > } / > < / Routes> < / BrowserRouter> ; import { useParams } from "react-router-dom" ; export default function Foo ( ) { const params = useParams ( ) ; return ( < div> < h1> { params. id} < / h1> < / div> ) ; }
useSearchParams 访问和修改查询参数
使用 useSearchParams hook 来访问和修改查询参数。其用法和 useState 类似,会返回当前对象和更改它的方法 使用 setSearchParams 时,必须传入所有的查询参数,否则会覆盖已有参数
import { useSearchParams } from "react-router-dom" ; function Foo ( ) { const [ searchParams, setSearchParams] = useSearchParams ( ) ; console. log ( searchParams. get ( "id" ) ) ; setSearchParams ( { name : "foo" , } ) ; return < div> foo< / div> ; }
路径匹配规则
当URL同时匹配到含有路径参数的路径和无参数路径时,优先匹配没有参数的”具体的“(specific)路径。
< Route path= "teams/:teamId" element= { < Team / > } / >
< Route path= "teams/new" element= { < NewTeamForm / > } / >
History 对象