为了账号安全,请及时绑定邮箱和手机立即绑定

React Router DOM 无法读取位置状态

React Router DOM 无法读取位置状态

慕沐林林 2022-06-05 11:07:31
我以前见过这个问题,但只适用于 Class 组件,所以我不确定如何将相同的方法应用于功能组件。这很简单,我有一个链接<Link to={{ pathname="/first-page" state: { name: "First person" }>First Page</Link>,然后在组件FirstPage.js中我需要读取name状态,所以我尝试了以下操作:import React from "react";export default props => {  React.useEffect(() => {     console.log(props)   }, []);   return (    <div>       <h1>First Page</h1>       <p>Welcome to first page, {props.location.state.name}</p>     </div>   );};我一直在阅读React Router 位置文档,它应该将状态作为组件属性传递,但事实并非如此。我很确定我做错了什么或根本没有看到。如果您想尝试整个代码,我将在这里留下一个CodeSandbox 项目来“测试”它。因此,关于我做错了什么的任何想法?提前致谢。
查看完整描述

2 回答

?
繁星coding

TA贡献1797条经验 获得超4个赞

这不是基于类与功能组件的问题,而是路由如何工作的问题。包裹的孩子不会收到路由参数,但使用Route's component、render或childrenprop 渲染的任何东西都会收到。


路由渲染方法


<Switch>

  <Route path="/first-page" component={FirstPage} />

  <Route path="/second-page" component={SecondPage} />

</Switch>

编辑 pedantic-banzai-dhz27


另一种选择是使用withRouterHOC 导出修饰的页面组件,或者如果是功能组件,则使用钩子。


带路由器


您可以通过高阶组件访问history对象的属性和最接近的属性 <Route>。 每当渲染时,都会将 updated 、和props 传递给包装的组件。matchwithRouterwithRoutermatchlocationhistory


const FirstPage = props => {

  React.useEffect(() => {

    console.log(props)

  }, []);


  return (

    <div>

      <h1>First Page</h1>

      <p>Welcome to first page, {props.location.state.name}</p>

    </div>

  );

};


export default withRouter(FirstPage);

挂钩


React Router 附带了一些hooks允许您访问路由器状态并从组件内部执行导航的功能。


const FirstPage = props => {

  const location = useLocation();


  console.log(location);


  return (

    <div>

      <h1>First Page</h1>

      <p>Welcome to first page, {location.state.name}</p>

    </div>

  );

};


export default FirstPage;


查看完整回答
反对 回复 2022-06-05
?
吃鸡游戏

TA贡献1829条经验 获得超7个赞

我发现你的路由器有问题。而不是使用:


 <Route path="/first-page">

    <FirstPage/>

 </Route>

利用:


<Route path="/first-page" component={FirstPage}/>

否则使用 library 提供的钩子let location = useLocation();,这样你就可以访问 location 对象。


查看完整回答
反对 回复 2022-06-05
  • 2 回答
  • 0 关注
  • 210 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号