Home > Web Front-end > Front-end Q&A > How to pass parameters in react router

How to pass parameters in react router

WBOY
Release: 2022-04-21 17:15:48
Original
4116 people have browsed it

How to pass parameters in react router: 1. Use wildcards to pass parameters. You can only pass strings. The parameters will not be lost when refreshing the page. 2. Use query to pass parameters. You can pass objects, but refreshing the page will Resulting in loss of parameters; 3. Use state to pass parameters. You can pass objects, arrays, etc. Once the page is refreshed, the parameters will be lost.

How to pass parameters in react router

The operating environment of this tutorial: Windows 10 system, react17.0.1 version, Dell G3 computer.

How to pass parameters in react router

There are three ways to pass parameters in react router routing: passing parameters through wildcards, query parameters and state parameters.

1. Wildcard parameter passing

Route definition method:

<Route path=&#39;/path/:name&#39; component={Path}/>
Copy after login

Link component:

<Link to="/path/通过通配符传参">通配符</Link>
Copy after login

Parameter acquisition:

this.props.match.params.name

Advantages: Simple and fast, and the parameters will not be lost when the page is refreshed.

Disadvantages: Only strings can be passed, and if too many values ​​are passed, the URL will become long and ugly.

If you want to transfer an object, you can use JSON.stringify() to convert it into a string, and then use JSON.parse() to convert it back after receiving it on another page.

2. query

Route definition method:

<Route path=&#39;/query&#39; component={Query}/>
Copy after login

Link component:

var query = {undefined
        pathname: &#39;/query&#39;,
        query: &#39;我是通过query传值 &#39;
}
Copy after login
<Link to={query}>query</Link>
Copy after login

Parameter acquisition:

this.props.location.query

Advantages: Elegant, transferable objects

Disadvantages: Refresh the page, parameters are lost

3, state

Route definition method:

<Link to={state}>state</Link>
Copy after login

Link component:

var state = {undefined
        pathname: &#39;/state&#39;,
        state: &#39;我是通过state传值&#39;
    }
    <Route path=&#39;/state&#39; component={State}/>
Copy after login

Parameter acquisition:

this.props.location.state

here this.props.location.state === 'I pass the value through query'

Advantages: elegant, can pass objects

Disadvantages: refresh the page, parameters are lost

Recommended learning: "react video tutorial"

The above is the detailed content of How to pass parameters in react router. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template