react 之路由

1 概念

从版本的React-Router5.x开始,路由彻底改变了,和以后的版本完全不兼容。所以出去开发时注意版本。

对当页面应用模式提供多页面效果

Link和useNavigate实现组件切换时,实计上伴随着组件的销毁与创建,所以建议只有整体页面切换时才使用路由,而局部切换时使用最原始的隐藏显示为佳,这样可以保让组件中通过ajax得到的数据一直存在。同样的道理,子路由的使用也需要特别小心

2 环境

(1)下载第三方模块

(a)ts开发情况下, 下载模块"react-router-dom"和 “@types/react-router-dom”

npm i --save react-router-dom @types/react-router-dom

(b)js开发情况下, 只需下载模块"react-router-dom"

(2)引入

import {  
	  BrowserRouter as Router, //BrowserRouter太长,常常使用别名Router
	  Route, 
      Routes,
      Link,
      useNavigate,
      useParams,
      useLocation,
      Navigate
} from 'react-router-dom';

BrowserRouter太长,常常使用别名Router

3 创建路由

<BrowserRouter>
				<Routes>
					<Route path='/main' element={<Main />} />
					<Route path='/one' element={<One />} />
					<Route path='/two' element={<Two />} />
				</Routes>
</BrowserRouter>
		 
<BrowserRouter>
  		  {/*Nav这个自定义组件与路由出来的界面同时显示, 页面跳转-Link和useNavigate可以在该组件中控制*/}
  			<Nav />
				<Routes>
					<Route path='/main' element={<Main />} />
					<Route path='/one' element={<One />} />
					<Route path='/two' element={<Two />} />
				</Routes>
</BrowserRouter>

4 页面跳转-Link和useNavigate

Link和useNavigate 必须位于BrowserRouter标签内部

Link相当于超连接

useNavigate是hook

import {Link, useNavigate} from 'react-router-dom';

Line标签
<Link to={
  {pathname:'/one'}}>one</Link>

或ts代码-useNavigate
let navigate = useNavigate();
function toTwo() {
		navigate({pathname:'/one'});
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值