当前位置: 首页 > news >正文

react router零基础使用教程

安装

既然学习 react router 就免不了运行 react

安装 react

npx create-react-app my-app
cd my-app
npm start

安装 react router

npm install react-router-dom

如果一切正常,就让我们打开 index.js 文件。

配置路由

引入 react-router-dom 的 RouterProvider

import {RouterProvider} from 'react-router-dom'

设置

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<React.StrictMode><RouterProvider router={routers}></RouterProvider></React.StrictMode>
);

这里的 React.StrictMode 代表以严格模式执行其包含的内容。

为了管理路由,让我们再创建一个 root.js 文件

内容如下:

文件:router.js

import {createBrowserRouter} from 'react-router-dom'
import App from '../App.js'
const router =  createBrowserRouter ([{path:'/',element:<App />,}
])
export default router;

添加一个新页面测试路由

新建文件:

test.js

export default function Test(){return(<div>测试页面</div>)
}

在 router.js 引入

import {createBrowserRouter} from 'react-router-dom'
import App from '../App.js'
import Test from '../test.js'
const router =  createBrowserRouter ([{path:'/',element:<App />,},{path:'/test',element:<Test />}
])
export default router;

创建文件:

error.js

export default function Error(){return (<h1>Page not found</h1>)
}

使用 errorElement属性 对应这个页面:

import {createBrowserRouter} from 'react-router-dom'
import App from '../App.js'
import Test from '../test.js'
import Error from '../error.js'
const router =  createBrowserRouter ([{path:'/',element:<App />,errorElement:<Error />},{path:'/test',element:<Test />}
])
export default router;
import { useNavigate } from "react-router-dom";
function Test () {const navigate = useNavigate();function toTest2(){navigate("/test2",{state:'anny'});}return(<div onClick={toTest2}>跳转页面</div>)
}
export default Test

使用 useLocation 接收值:

import {useLocation} from 'react-router-dom'
export default function Test2(){let location = useLocation();return (<div>页面Test2 接收到的值为 {location.state}</div>)
}

通过 dom

通过 Link 传值跳转:

import {Link } from "react-router-dom";
function Test () {return(<div><Link to="/test2" state={'anny'} >跳转页面</Link></div>)
}
export default Test

使用 useLocation 接收值:

import {useLocation} from 'react-router-dom'
export default function Test2(){let location = useLocation();return (<div>页面Test2 接收到的值为 {location.state}</div>)
}

嵌套页面

平时写管理后台,经常会看到左右分布的布局,如果仅仅依靠 1-5 节的内容肯定很难实现,接下来看一下 根布局。

根布局使用 :

创建一个 父页面,父页面放置两个 链接:

parent.js

import { Link, Outlet } from "react-router-dom";
function Parent(){return(<div><Link to={'/parent/page1'}>show page1</Link><Link to={'/parent/page2'}>show page2</Link><Outlet></Outlet></div>)
}
export default Parent;

继续创建 两个页面 page1.js page2.js

page1.js

function Page1(){return(<div>i am page1</div>)
}
export default Page1;

page2.js

function Page2(){return(<div>i am page2</div>)
}
export default Page2;

修改我们的 router.js 文件:

import {createBrowserRouter} from 'react-router-dom'
import App from '../App.js'
import Test from '../test.js'
import Error from '../error.js'
import Parent from '../parent.js'
import Page1 from '../page1.js'
import Page2 from '../page2.js'
const router =  createBrowserRouter ([{path:'/',element:<App />,errorElement:<Error />,},{path:'/test',element:<Test />},{path:'/parent',element:<Parent />,children:[{path:'/parent/page1',element:<Page1 />},{path:'/parent/page2',element:<Page2 />}]}
])
export default router;

到这里还差一步,就是使用重要的标签 <Outlet>

修改我们的父页面

parent.js

import { Link, Outlet } from "react-router-dom";
function Parent(){return(<div><Link to={'/parent/page1'}>show page1</Link><Link to={'/parent/page2'}>show page2</Link><Outlet></Outlet></div>)
}
export default Parent;

分别点击 show page1show page2 你将看到不同的效果。

如果你想将第一个子组件默认展示出来,你可以将 router.js 改成如下:

    {path:'/parent',element:<Parent />,children:[{path:'/parent',element:<Page1 />},{path:'/parent/page2',element:<Page2 />}]}

再看一下效果:

http://www.lryc.cn/news/32746.html

相关文章:

  • IOC三种依赖注入的方式,以及区别
  • Ubuntu18安装新版本PCL-1.13,并和ROS自带PCL-1.8共存
  • 计算机图形学08:中点BH算法绘制抛物线(100x = y^2)
  • 基于java的高校辅导员工作管理系统
  • 字节3次都没裁掉的7年老测试。掌握设计业务与技术方案,打开上升通道!
  • 详细介绍关于链表【数据结构】
  • 2.3 二分搜索技术
  • RWEQ模型的土壤风蚀模数估算、其变化归因分析
  • 学习streamlit-1
  • GPS定位知识介绍
  • 【Linux】理解Linux环境变量
  • ISCSI块存储-集群
  • 11.Maxwell 部署
  • 一文速学-GBDT模型算法原理以及实现+Python项目实战
  • 前端——2.HTML基本结构标签
  • OAK深度相机使用不同镜头和本地视频流进行模型推理
  • [项目] Boost搜索引擎
  • 解决新版QGIS找不到Georeferencer插件
  • c---冒泡排序模拟qsort
  • Java知识复习(十四)JS
  • 代码随想录刷题-数组-移除元素
  • 聚观早报 |拼多多跨境电商业务正式登陆澳洲;中国加快6G网络研发
  • MDK Keil5 创建Stm32工程-理论篇(这里以Stm32F103Zet6为例)
  • 应届大学生学什么技术好?哪些技术适合年轻人?
  • 车企数据分类分级的实践指南出炉!“数据安全推进计划”发布,奇点云参编
  • Nginx学习 (2) —— 虚拟主机配置
  • Java 动态代理简述和实例
  • Unity编译器扩展(Advanced Editor Scripting)
  • AFR机制及流程介绍
  • 9.Hbase 部署