search
HomeWeb Front-endCSS TutorialThe Hooks of React Router

The Hooks of React Router

React Router v5 introduces a powerful Hook mechanism, providing four convenient routing hooks, simplifying routing management. This article will quickly get started with the new mode of React Router v5, first introducing the new routing rendering mode, and then delving into the use of each Hook.

React Router before v5

 // Render the route and get the route attributes<route component="{Home}" path="/"></route>

// Pass extra properties<route path="/" render="{({" match><profile match="{match}" mine="{true}"></profile> } /></route>

When using component syntax, routing properties ( match , location , and history ) are implicitly passed to the component. But if you need to pass additional properties, you must use render property instead. It should be noted that adding inline functions to the component syntax will cause the component to remount each time it is rendered.

React Router after v5

<route path="/"><home></home></route>

Home component no longer implicitly receives routing properties. However, you can add any extra properties to Home component without modifying Route itself. Avoid the problem of remounting components every time they render, which is a more concise and efficient API design.

Since routing properties are no longer implicitly passed, how to access match , history , or location ? Do I need to wrap all components with withRouter ? This is where the Hook comes into play.

Note that the Hook was introduced in React 16.8, so React is required to be used.

useHistory Hook

  • Provides access to history attributes in React Router.
  • Points to history package dependencies used by the route.
  • It is mainly used for programmatic routing through functions, such as push , replace , etc.
 import { useHistory } from 'react-router-dom';

function Home() {
  const history = useHistory();
  return <button onclick="{()">history.push('/profile')}>Profile</button> ;
}

useLocation Hook

  • Provides access to location attribute in the React Router.
  • Similar to the browser's window.location , but it represents the routing status and location and can be accessed anywhere.
  • Mainly used to access query parameters or complete routing strings.
 import { useLocation } from 'react-router-dom';

function Profile() {
  const location = useLocation();
  useEffect(() => {
    const currentPath = location.pathname;
    const searchParams = new URLSearchParams(location.search);
    // ... Use currentPath and searchParams
  }, [location]);
  Return<p> Profile</p> ;
}

Since location property is immutable, useEffect calls the function every time the route changes, which is great for manipulating search parameters or current paths.

useParams Hook

  • Provides access to parameters in the URL.
  • This feature was previously only implemented through match.params .
 import { useParams, Route } from 'react-router-dom';

function Profile() {
  const { name } = useParams();
  Return<p> {name}'s Profile</p> ;
}

function Dashboard() {
  Return (
    <div>
      <nav>
        <link to="{`/profile/ann`}">Ann's Profile
      </nav>
      <main>
        <route path="/profile/:name"><profile></profile></route>
      </main>
    </div>
  );
}

useRouteMatch Hook

  • Provides access to match objects.
  • If there is no argument, the closest match in the component or its parent component is returned.
  • Mainly used to build nested paths.
 import { useRouteMatch, Route } from 'react-router-dom';

function Auth() {
  const match = useRouteMatch();
  Return (
    <div>
      <route path="{`${match.url}/login`}"><login></login></route>
      <route path="{`${match.url}/register`}"><register></register></route>
    </div>
  );
}

useRouteMatch can also be used to access match objects without rendering Route by passing location parameters.

For example, suppose you need to render your profile in /profile , and if the URL contains the person's name ( /profile/dan or /profile/ann ), render the profile of others. If you don't use a Hook, you need to write a Switch , list two routes and customize with props. But now, using Hook can do this:

 import { Route, BrowserRouter as Router, Link, useRouteMatch } from 'react-router-dom';

function Profile() {
  const match = useRouteMatch('/profile/:name');
  return match?<p> {match.params.name}'s Profile</p> :<p> My own profile</p> ;
}

export default function App() {
  Return (
    <router>
      <nav>
        <link to="/profile">My Profile
        <br>
        <link to="{`/profile/ann`}">Ann's Profile
      </nav>
      <route path="/profile"><profile></profile></route>
    </router>
  );
}

You can also pass all Route properties like exact or sensitive as objects to useRouteMatch .

Summarize

Hook and explicit Route themselves have hidden advantages. These Hooks help avoid much of the confusion and complexity that emerged in early modes, reduce human errors, make routing code easier to maintain, and easier to upgrade to the new React Router version.

The above is the detailed content of The Hooks of React Router. For more information, please follow other related articles on the PHP Chinese website!

Statement
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
Iterating a React Design with Styled ComponentsIterating a React Design with Styled ComponentsApr 21, 2025 am 11:29 AM

In a perfect world, our projects would have unlimited resources and time. Our teams would begin coding with well thought out and highly refined UX designs.

Oh, the Many Ways to Make Triangular Breadcrumb Ribbons!Oh, the Many Ways to Make Triangular Breadcrumb Ribbons!Apr 21, 2025 am 11:26 AM

Oh, the Many Ways to Make Triangular Breadcrumb Ribbons

SVG Properties in CSS GuideSVG Properties in CSS GuideApr 21, 2025 am 11:21 AM

SVG has its own set of elements, attributes and properties to the extent that inline SVG code can get long and complex. By leveraging CSS and some of the forthcoming features of the SVG 2 specification, we can reduce that code for cleaner markup.

A Few Functional Uses for Intersection Observer to Know When an Element is in ViewA Few Functional Uses for Intersection Observer to Know When an Element is in ViewApr 21, 2025 am 11:19 AM

You might not know this, but JavaScript has stealthily accumulated quite a number of observers in recent times, and Intersection Observer is a part of that

Revisting prefers-reduced-motionRevisting prefers-reduced-motionApr 21, 2025 am 11:18 AM

We may not need to throw out all CSS animations. Remember, it’s prefers-reduced-motion, not prefers-no-motion.

How to Get a Progressive Web App into the Google Play StoreHow to Get a Progressive Web App into the Google Play StoreApr 21, 2025 am 11:10 AM

PWA (Progressive Web Apps) have been with us for some time now. Yet, each time I try explaining it to clients, the same question pops up: "Will my users be

The Simplest Ways to Handle HTML IncludesThe Simplest Ways to Handle HTML IncludesApr 21, 2025 am 11:09 AM

It's extremely surprising to me that HTML has never had any way to include other HTML files within it. Nor does there seem to be anything on the horizon that

Change Color of SVG on HoverChange Color of SVG on HoverApr 21, 2025 am 11:04 AM

There are a lot of different ways to use SVG. Depending on which way, the tactic for recoloring that SVG in different states or conditions — :hover,

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor