react中简单的配置路由

1.安装react-router-dom

javascript 复制代码
npm install react-router-dom

2.新建文件

src下新建page文件夹,该文件夹下新建login和index文件夹用于存放登录页面和首页,再在对应文件夹下分别新建入口文件index.js;

src下新建router文件用于存放路由配置文件,该文件夹下新建入口文件index.js;

3.实现过程

3.1页面的编写

src/page/index/index.js

javascript 复制代码
function IndexPage() {
  return (
    <div>
      欢迎来到index
    </div>
  );
}

export default IndexPage;

src/page/login/index.js

javascript 复制代码
function LoginPage() {
  return (
    <div>
      欢迎来到login
    </div>
  );
}

export default LoginPage;

3.2路由文件配置

src/router/index.js

javascript 复制代码
// 1.引入方法,用于创建路由实例
import { createBrowserRouter } from 'react-router-dom' 

// 2.引入组件
import LoginPage from '../page/login';
import IndexPage from '../page/index';

// 3.创建router实例,配置路由
const router = createBrowserRouter([ 
  {
    path:"/login", // 路由路径
    element:<LoginPage></LoginPage> // 渲染页面的地方
  },
  {
    path:"/index",
    element:<IndexPage></IndexPage>
  },
  {
    path:"",
    element:<div>欢迎来到首页</div>
  }
])

// 4.暴露路由实例,用于在App.js主入口组件
export default router;

3.3路由绑定

javascript 复制代码
import React, { useState, useRef, useEffect, useContext, createContext } from 'react';
// 1.引入
import { RouterProvider } from 'react-router-dom'
import router from './router';



function App() {
  return (
    <div>
      {/* 2.绑定 */}
      <RouterProvider router={router}></RouterProvider>
    </div>
  );
}

export default App;

4.最终效果

相关推荐
铅笔侠_小龙虾15 分钟前
Flutter Demo
开发语言·javascript·flutter
2501_9445255424 分钟前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
2601_9498574329 分钟前
Flutter for OpenHarmony Web开发助手App实战:快捷键参考
前端·flutter
wangdaoyin201036 分钟前
若依vue2前后端分离集成flowable
开发语言·前端·javascript
天天进步20151 小时前
AI Agent 与流式处理:Motia 在生成式 AI 时代的后端范式
javascript
心柠1 小时前
vue3相关知识总结
前端·javascript·vue.js
Amumu121381 小时前
Vue Router(二)
java·前端
a1117762 小时前
图书借阅管理系统(FastAPI + Vue)
前端·vue.js·fastapi
常年游走在bug的边缘2 小时前
掌握JavaScript作用域:从函数作用域到块级作用域的演进与实践
开发语言·前端·javascript
极致♀雨3 小时前
vue2+elementUI table表格勾选行冻结/置顶
前端·javascript·vue.js·elementui