React-router v7 第四章(路由传参)
参数传递
React-router 一共有三种方式进行参数传递,参数传递指的是在路由跳转时,将参数传递给目标路由。
Query方式
Query的方式就是使用 ? 来传递参数,例如:
#多个参数用 & 连接
/user?name=小满zs&age=18
跳转方式:
<NavLink to="/about?id=123">About</NavLink> //1. NavLink 跳转
<Link to="/about?id=123">About</Link> //2. Link 跳转
import { useNavigate } from 'react-router'
const navigate = useNavigate()
navigate('/about?id=123') //3. useNavigate 跳转
获取参数:
//1. 获取参数
import { useSearchParams } from 'react-router'
const [searchParams, setSearchParams] = useSearchParams()
console.log(searchParams.get('id')) //获取id参数
//2. 获取参数
import { useLocation } from 'react-router'
const { search } = useLocation()
console.log(search) //获取search参数 ?id=123
Params方式
Params的方式就是使用 :[name] 来传递参数,例如:
/user/:id
跳转方式:
<NavLink to="/user/123">User</NavLink> //1. NavLink 跳转
<Link to="/user/123">User</Link> //2. Link 跳转
import { useNavigate } from 'react-router'
const navigate = useNavigate()
navigate('/user/123') //3. useNavigate 跳转
获取参数:
import { useParams } from 'react-router'
const { id } = useParams()
console.log(id) //获取id参数
State方式
state在URL中不显示,但是可以传递参数,例如:
/user
跳转方式:
<Link to="/user" state={{ name: '小满zs', age: 18 }}>User</Link> //1. Link 跳转
<NavLink to="/user" state={{ name: '小满zs', age: 18 }}>User</NavLink> //2. NavLink 跳转
import { useNavigate } from 'react-router'
const navigate = useNavigate()
navigate('/user', { state: { name: '小满zs', age: 18 } }) //3. useNavigate 跳转
获取参数:
import { useLocation } from 'react-router'
const { state } = useLocation()
console.log(state) //获取state参数
console.log(state.name) //获取name参数
console.log(state.age) //获取age参数
总结
React Router 提供了三种参数传递方式,各有特点:
1. Params 方式 (/user/:id
)
- 适用于:传递必要的路径参数(如ID)
- 特点:符合 RESTful 规范,刷新不丢失
- 限制:只能传字符串,参数显示在URL中
2. Query 方式 (/user?name=xiaoman
)
- 适用于:传递可选的查询参数
- 特点:灵活多变,支持多参数
- 限制:URL可能较长,参数公开可见
3. State 方式
- 适用于:传递复杂数据结构
- 特点:支持任意类型数据,参数不显示在URL
- 限制:刷新可能丢失,不利于分享
选择建议:必要参数用 Params,筛选条件用 Query,临时数据用 State。