react router路由传参的三种方式

本文详细介绍了React中三种路由传参方法:通配符传参、query和state,对比了它们各自的优缺点,如是否支持对象传递及刷新页面时参数的表现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.通配符传参

  • Route定义方式:<Route path='/About/:id' component={About} />
  • Link组件:<Link to="/path/通过通配符传参">About</Link>
  • 参数获取:this.props.location.query

优点:简单快捷,并且,在刷新页面的时候,参数不会丢失。

缺点:只能传字符串,并且,如果传的值太多的话,url会变得长而丑陋。

如果,你想传对象的话,可以用JSON.stringify(),想将其转为字符串,然后另外的页面接收后,用JSON.parse()转回去。这里简单提一下,不赘述。

2.query

  • Route定义方式:<Route path='/Home' component={Home} />
  • Link组件:var query = { pathname: '/Home', query: '我是通过query传值 ' } <Link to={query}>Home</Link>
  • 参数获取:this.props.location.query

优点:优雅,可传对象

缺点:刷新页面,参数丢失

3.state

  • Route定义方式:<Route path='/Download' component={Download} />
  • Link组件:<Link to={{pathname: '/Download',state:'这是state传值'}}>Download</Link>
  • 参数获取:this.props.location.state

优点:优雅,可传对象

缺点:刷新页面,参数丢失

### react-router-dom 路由传参的方法 #### 使用 URL 参数传递数据 URL 参数是一种常见的路由间传递静态或动态信息的方式。当路径模式中包含冒号 `:` 开头的部分时,则这部分会被视为参数。 ```javascript import { useParams } from 'react-router-dom'; const UserProfile = () => { let { userId } = useParams(); return ( <div> <h1>用户ID: {userId}</h1> </div> ); }; ``` 此代码展示了如何定义带有参数 `/user/:userId` 的路径并读取该参数[^3]。 #### 通过 Link 组件的 to 属性中的 state 对象来传递状态 除了利用 URL 来携带简单类型的参数外,还可以借助 `<Link>` 或编程方式导航时附加的状态对象来进行更复杂的数据传输。 ```jsx // 发送方组件内 <Link to={{ pathname: "/target", search: "?sort=name", // 可选查询字符串 hash: "#section1", // 可选锚点 state: { detail: true } }} > Go to Target Page with State Data </Link> // 接收方组件内访问state useEffect(() => { if (location.state && location.state.detail) { console.log('接收到额外的状态:', location.state); } }, [location]); ``` 这种方式适合于不想让参数显示在地址栏里的情况,比如敏感信息或是较大的结构化数据[^4]。 #### 利用 Query String 查询串形式发送键值对 对于一些简单的过滤条件或者是分页场景下,可以考虑采用查询字符串的形式进行参数附带: ```html <a href="?page=2&size=10">前往第一页每页十条记录</a> ``` 接收端可以通过 `useSearchParams()` Hook 获取到所有的查询参数,并对其进行解析处理[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值