首页 > web前端 > js教程 > 如何在 React Router 页面之间高效传递数据?

如何在 React Router 页面之间高效传递数据?

Linda Hamilton
发布: 2024-12-17 06:59:25
原创
630 人浏览过

How to Efficiently Pass Data Between React Router Pages?

如何使用 React Router 将数据从一个页面传递到另一个页面

问题:

从项目列表中导航到详细信息页面,传递所选的详细信息

解决方案:

使用React Router在页面之间传递数据主要有以下三个选项:

选项1:传递路由状态

发送路线中的项目 ID状态:

v6(声明式):

<Link to="/home/userDetails" state={{ infoId: info.id }}>...</Link>
登录后复制

v6(命令式):

import { useNavigate } from "react-router-dom";

const navigate = useNavigate();
navigate("/home/userDetails", { state: { infoId: info.id } });
登录后复制

v5 (声明式):

<Link to={{ pathname: '/home/userDetails', state: { infoId: info.id } }}>...</Link>
登录后复制

v5 (命令式):

import { useHistory } from "react-router-dom";

const history = useHistory();
history.push({ pathname: '/home/userDetails', state: { infoId: info.id } });
登录后复制

接收目的地的状态组件:

v6:

const { state: { infoId } = {} } = useLocation();
登录后复制

v5:

if (props.location && props.location.state && props.location.state.infoId) {
  // Access info ID
}
登录后复制

选项 2:传递一些东西在 URL 路径

包含该项目URL路径中的ID:

<Link to={`/home/userDetails/${info.id}`}>...</Link>
登录后复制

接收目标组件中的参数:

v6:

const { infoId } = useParams();
登录后复制

v5 :

const infoId = props.match.params.infoId;
登录后复制

选项3:在 URL 查询字符串中传递某些内容

将项目 ID 附加到 URL 查询字符串:

v6(声明式):

<Link to={{ pathname: '/home/userDetails', search: `?infoId=${info.id}` }}>...</Link>
登录后复制
登录后复制

v6 (命令式):

import { useNavigate } from "react-router-dom";

const navigate = useNavigate();
navigate({ pathname: '/home/userDetails', search: `?infoId=${info.id}` });
登录后复制

v5(声明式):

<Link to={{ pathname: '/home/userDetails', search: `?infoId=${info.id}` }}>...</Link>
登录后复制
登录后复制

v5(命令式):

import { useHistory } from "react-router-dom";

const history = useHistory();
history.push({ pathname: '/home/userDetails', search: `?infoId=${info.id}` });
登录后复制

在目的地接收查询参数组件:

v6:

const [searchParams] = useSearchParams();
const infoId = searchParams.get("infoId");
登录后复制

v5:

if (props.location && props.location.search) {
  const searchParams = new URLSearchParams(props.location.search);
  const infoId = searchParams.get("infoId");
}
登录后复制

以上是如何在 React Router 页面之间高效传递数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板