既然学习 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})
}通过 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: }]}
再看一下效果: