您现在的位置是:网站首页> 编程资料编程资料
react router零基础使用教程_vue.js_
2023-05-24
225人已围观
简介 react router零基础使用教程_vue.js_
安装
既然学习 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;保存
在浏览器访问 http://localhost:3000/test
你应该可以看到:

配置未找到的路由
现在我们有 App.js 和 test.js 两个页面,如果访问 http://localhost:3000/hello 会出现什么呢?

这是内置的页面,提醒用户没有找到页面。
接下来使用美化或者自定义的页面:
创建文件:
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;继续请求 http://localhost:3000/hello

我们刚才自定义的页面成功展示出来了。
跳转页面
跳转页面有很多,这里取两种方式,一是通过 dom 标签,二是通过js
通过 js
使用 useNavigate 跳转页面:
看起来就像这样:
test.js
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; 保存:
接下来访问 http://localhost:3000/parent 你将看到:

分别点击 show page1 和 show page2 你将看到不同的效果。
如果你想将第一个子组件默认展示出来,你可以将 router.js 改成如下:
{ path:'/parent', element: , children:[ { path:'/parent', element: }, { path:'/parent/page2', element: } ] } 再看一下效果:

到此这篇关于react router零基础使用教程的文章就介绍到这了,更多相关react router内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- vue后台系统管理项目之角色权限分配管理功能(示例详解)_vue.js_
- React组件的应用介绍_React_
- JavaScript获取echart曲线上任意点位的值详解_vue.js_
- React事件处理超详细介绍_React_
- React state状态属性详细讲解_React_
- JavaScript前端学算法题解LeetCode最大重复子字符串_JavaScript_
- ElementUI修改实现更好用图片上传预览组件_vue.js_
- JavaScript手写LRU算法的示例代码_javascript技巧_
- vue项目是如何运行起来的_vue.js_
- 关于字符串和对象互转以及JSON.parse()的坑_javascript技巧_
