react router零基础使用教程
创始人
2024-05-29 22:45:04

安装

既然学习 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 代表以严格模式执行其包含的内容。

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

内容如下:

文件:router.js

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

添加一个新页面测试路由

新建文件:

test.js

export default function Test(){return(
测试页面
) }

在 router.js 引入

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

创建文件:

error.js

export default function Error(){return (

Page not found

) }

使用 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:,errorElement:},{path:'/test',element:}
])
export default router;
import { useNavigate } from "react-router-dom";
function Test () {const navigate = useNavigate();function toTest2(){navigate("/test2",{state:'anny'});}return(
跳转页面
) } export default Test

使用 useLocation 接收值:

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

通过 dom

通过 Link 传值跳转:

import {Link } from "react-router-dom";
function Test () {return(
跳转页面
) } export default Test

使用 useLocation 接收值:

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

嵌套页面

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

根布局使用 :

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

parent.js

import { Link, Outlet } from "react-router-dom";
function Parent(){return(
show page1show page2
) } export default Parent;

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

page1.js

function Page1(){return(
i am page1
) } export default Page1;

page2.js

function Page2(){return(
i am page2
) } 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:,errorElement:,},{path:'/test',element:},{path:'/parent',element:,children:[{path:'/parent/page1',element:},{path:'/parent/page2',element:}]}
])
export default router;

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

修改我们的父页面

parent.js

import { Link, Outlet } from "react-router-dom";
function Parent(){return(
show page1show page2
) } export default Parent;

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

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

    {path:'/parent',element:,children:[{path:'/parent',element:},{path:'/parent/page2',element:}]}

再看一下效果:

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...