React Router 5.1.0 uses useHistory to implement page jump navigation

React Router 5.1.0 uses useHistory to implement page jump navigation

In React Router v4 you can use

  1. withRouter Component
  2. Use Tags

1. Use the withRouter component

The withRouter component will inject the history object as a property of the component

import React from 'react'
import { withRouter } from 'react-router-dom'
import { Button } from 'antd'

export const ButtonWithRouter = withRouter(({ history }) => {
  console.log('history', history)
  return (
    <Button
      type='default'
      onClick={() => { history.push('/new-location') }}
    >
      Click Me!
    </Button>

  )
})

image.jpg

import { ButtonWithRouter } from './buttonWithRouter'

or:

const ButtonWithRouter = (props) => {
  console.log('props', props)
  return (
    <Button
      type='default'
      onClick={() => { props.history.location.push('/new-location') }}
    >
      Click Me!
    </Button>

  )
}

export default withRouter(ButtonWithRouter)

image.jpg

Import: import ButtonWithRouter from './buttonWithRouter'

2. Use Route Tags

At the route entrance

image.jpg

The Route component is not only used for matching locations. You can render a route without a path and it will always match the current location. The Route component passes the same properties as withRouter, so the history methods can be accessed through the history properties.

so:

export const ButtonWithRouter = () => (
  <Route render={({ history }) => {
    console.log('history', history)
    return (
      <button
        type='button'
        onClick={() => { history.push('/new-location') }}
      >
        Click Me!
      </button>
    )
  }} />
) 

image.jpg

React Router 5.1.0 uses useHistory

Starting from React Router v5.1.0, the useHistory hook has been added. If you are using React >16.8.0, you can use useHistory to achieve page jump

export const ButtonWithRouter = () => {
  const history = useHistory();
  console.log('history', history)
  return (
    <button
      type='button'
      onClick={() => { history.push('/new-location') }}
    >
      Click Me!
    </button>
  )
}

image.jpg

This is the end of this article about the implementation of page jump navigation using useHistory in React Router 5.1.0. For more relevant ReactRouter useHistory page jump navigation content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • An example of implementing a breadcrumb navigation using React high-order components
  • React Navigation for Android Development Navigation Bar Style Adjustment + Bottom Corner Message Prompt
  • React Native react-navigation navigation usage details
  • Detailed explanation of cross-tab routing processing in React Native using react-navigation
  • Detailed explanation of React Native top and bottom navigation usage tips
  • React-native example of using react-navigation for page jump navigation
  • React realizes secondary linkage of navigation bar

<<:  Flash embedded in HTML Solution for embedding Flash files in HTML web page code (Part 1)

>>:  MySQL uses events to complete scheduled tasks

Recommend

How to generate Hive table creation statement comment script in MySQL metadata

Preface This article mainly introduces the releva...

8 JS reduce usage examples and reduce operation methods

reduce method is an array iteration method. Unlik...

HTML page native VIDEO tag hides the download button function

When writing a web project, I encountered an intr...

Comprehensive inventory of important log files in MySQL

Table of contents Introduction Log classification...

CSS modular solution

There are probably as many modular solutions for ...

JavaScript selector functions querySelector and querySelectorAll

Table of contents 1. querySelector queries a sing...

A brief discussion on size units in CSS

The compatibility of browsers is getting better a...

How to make a centos base image

Preface Now the operating system used by my compa...

Introduction to Kubernetes (k8s)

I had always wanted to learn Kubernetes because i...

Vue implements tab navigation bar and supports left and right sliding function

This article mainly introduces: using Vue to impl...

Detailed explanation of the process of zabbix monitoring sqlserver

Let's take a look at zabbix monitoring sqlser...

Teach you how to deploy zabbix service on saltstack

Table of contents Saltstack deploys zabbix servic...

Example of converting timestamp to Date in MySQL

Preface I encountered a situation at work: In the...