Simple analysis of react-router routing
This article mainly introduces a simple analysis of react-router routing, which has a certain reference value. Now I share it with everyone. Friends in need can refer to it
What we want is a simple react -router routing
What we want is a simple react-router routing
I am used to the usage of vue-router routing, but it always feels quite troublesome to use react-router again.
So is there any way to use react with a simple routing plug-in like vue-router?
Whether it is there or not, I have already built the wheel, please accept it.
react-concise-router
react-concise-router
is a routing plug-in based on react-router v4.x package.
1. Installation
Direct installation
npm install -S react-concise-router
You also need to install
npm install -S react-router
npm install -S react-router-dom
2. Define routing list objects
router.js
import Router from 'react-concise-router' import Home from './views/Home' import User from './views/User' import UserInfo from './views/UserInfo' import ErrorPage from './views/Error' import view from './views/admin/view' import Dashboard from './views/admin/Dashboard' const router = new Router ({ mode: 'hash', routes: [ {path: '/', component: Home}, {path: '/user', component: User}, {path: '/user/:userId', name: 'info', component: UserInfo}, { path: '/admin', component: view, name: 'admin-view', children: [ {path: '/', component: Dashboard}, {path: '/test', component: Dashboard}, {component: ErrorPage} ] }, {path: '*', component: ErrorPage}, ] }) export default router
App.jsx
import React from 'react' import router from './router' export default class App extends React.Component { render () { return ( <p> <p>wellcome !</p> <router.view /> </p> ) } }
API
new Router(options) Create a routing object and return router.
options object object of routing configuration
options.mode string defines the routing type, hash|history
options.routes array route list
options.routes[].name string route name, if the children attribute currently exists, it indicates the route exit name
options.routes[].path string path
options.routes[].component Function routing component; if the children attribute currently exists, it represents the child routing component
##options.routes [].children array sub-route list
options.pathrouterdoes not exist or is
*. The route will be treated as a notMath route and matched. 404
router.route(route) Generate url for history.push.
router.beforeEach(cxt, next) Routing switching middleware
is a routing export component.
props
props.name string route export subname, default 'default'; in options .routes[].name
settings.
router.link is a component similar to
Link.
props
props.to object|string path or path object route.
router.beforeEach is a routing middleware, you can do some routing switching events; such as authorization interception, redirection , waiting for operations.
router.beforeEach = function (ctx, next) {}
ctx This is a context object, {route, router, history,... }
next This is a callback function, please call it at the end; next
can accept a string path or object, so Redirect to other routes.
route.name string named route name, takes precedence over path
route.path string path
route.params object route parameter object
route.query object query string object
route.hash string link hash
Analysis of React components and state|props
The above is the detailed content of Simple analysis of react-router routing. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Calling method: 1. Calls in class components can be implemented by using React.createRef(), functional declaration of ref or props custom onRef attribute; 2. Calls in function components and Hook components can be implemented by using useImperativeHandle or forwardRef to throw a child Component ref is implemented.

How to debug React source code? The following article will talk about how to debug React source code under various tools, and introduce how to debug the real source code of React in contributors, create-react-app, and vite projects. I hope it will be helpful to everyone!

React custom Hooks are a way to encapsulate component logic in reusable functions. They provide a way to reuse state logic without writing classes. This article will introduce in detail how to customize encapsulation hooks.

Why doesn’t React use Vite as the first choice for building applications? The following article will talk to you about the reasons why React does not recommend Vite as the default recommendation. I hope it will be helpful to everyone!

How to set the div height in react: 1. Implement the div height through CSS; 2. Declare an object C in the state and store the style of the change button in the object, then get A and reset the "marginTop" in C. That is Can.

This article will share with you 7 great and practical React component libraries that are often used in daily development. Come and collect them and try them out!
![[Translation] Refactoring React components using custom hooks](https://img.php.cn/upload/article/000/000/024/63c690a1b11d0794.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
I often hear people talk about React function components, mentioning that function components will inevitably become larger and more logically complex. After all, we wrote the component in "a function", so you have to accept that the component will expand and the function will continue to expand.

When developing front-end projects, state management is always an unavoidable topic. The Vue and React frameworks themselves provide some capabilities to solve this problem. However, there are often other considerations when developing large-scale applications, such as the need for more standardized and complete operation logs, time travel capabilities integrated in developer tools, server-side rendering, etc. This article takes the Vue framework as an example to introduce the differences in the design and implementation of the two state management tools, Vuex and Pinia.
