【react学习】react-router-dom v5如何进行路由跳转

首先注明我用的项目依赖版本
  • react 【^18.2.0】
  • react-dom【^18.2.0】
  • react-router-dom【^5.2.0】
  • @types/react-router-dom【^5.3.3】

注:一般情况只需要安装react-router-dom依赖就好,但如果你使用了typeScript那么就需要安装@types/react-router-dom,否则没有类型声明会报错

一,安装路由依赖
npm i react-router-dom@5.2.0 @types/react-router-dom@5.3.3 --save
二,注册路由

在根目录下新建routes.ts(在哪里新建都行)

// 导入路由组件
import Page1 from './pages/page1'
import Page2 from './pages/page2'

const routes = [
	{
		path: '/page1',
		exact: true,
		component: Page1
	},
	{
		path: '/page2',
		exact: true,
		component: Page2
	}
]

export default routes;
三,使用路由并挂载

在App.tsx中编写如下代码,路由注册有两种写法

import React from 'react';
import routes from './routes';

import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';

function App() {
  return (
    <Router>
      <div className="app-container">
        <Switch>
          {
            routes.map((item:any) => {
              return (
              	// 写法一
                <Route path={item.path} key={item.path} component={item.component} />

				// 写法二
				<Route path={item.path} key={item.path}>
					{item.component}
				</Route>
              )
            })
          }
        </Switch>
      </div>
    </Router>
  );
}

export default App;
四,写法一和写法二的注意事项

在 React Router 中,如果你在 Route 组件上使用 component 属性来渲染组件,会自动将 match、location 和 history 这三个对象作为属性传递给这个组件。这是因为 Route 组件内部使用了高阶组件技术(HOC),在渲染组件时将这些参数注入到组件的 props 中,而访问history和核心代码是this.props.history

写法一:如果你直接在Route标签上传递了component属性,那么你可以在Page1或Page2或你自己的组件中通过useHistory来跳转路由

写法二:根据上诉所说,如果你使用标签嵌套的方式来注册组件,这个时候,你在组件中通过const history = useHistory()来获取history对象,history的值为undefined,导致无法跳转路由,甚至是报错,解决方案如下:
在这里插入图片描述

五,修改index.tsx中的代码

其实做完上面几步,在地址栏改变路由就可以跳转页面了,但是我们一般在项目中会使用history或其他方式来跳转路由,如果你不修改如下代码,会造成路由变了,但是页面不更新的问题

import React from 'react';
import ReactDOM from 'react-dom/client';
import reportWebVitals from './reportWebVitals';

import App from './App'

const root = ReactDOM.createRoot(
	document.getElementById('root') as HTMLElement
);

root.render(
	//这里的React.StrictMode需要删掉,否则会造成页面不刷新
	//<React.StrictMode>
	<App />
	// </React.StrictMode>
);

reportWebVitals();
ok~接下来你就能随心所欲的在项目中使用路由跳转页面了
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React Router v5 中,你可以使用 React.lazy() 和 Suspense 组件来实现路由的懒加载。下面是一个示例: 首先,确保你已经安装了 `react-router-dom` 的版本为 5.x。 ```bash npm install react-router-dom@5 ``` 然后,你可以按照以下步骤来实现路由的懒加载: 1. 导入需要使用的组件和函数: ```jsx import React, { Suspense, lazy } from 'react'; import { BrowserRouter as Router, Route, Switch } from 'react-router-dom'; ``` 2. 创建需要懒加载的组件: ```jsx const Home = lazy(() => import('./components/Home')); const About = lazy(() => import('./components/About')); const Contact = lazy(() => import('./components/Contact')); ``` 3. 使用懒加载的组件和路由: ```jsx function App() { return ( <Router> <Suspense fallback={<div>Loading...</div>}> <Switch> <Route exact path="/" component={Home} /> <Route path="/about" component={About} /> <Route path="/contact" component={Contact} /> </Switch> </Suspense> </Router> ); } export default App; ``` 在上面的代码中,`Suspense` 组件用于在组件加载期间显示一个加载提示(例如 "Loading..."),直到组件加载完成。`fallback` 属性指定了加载期间显示的内容。 `lazy` 函数用于动态导入组件。传递给 `lazy` 函数的参数是一个返回 `import()` 方法的函数,该方法会异步加载组件。 在 `Route` 组件中,将懒加载的组件作为 `component` 属性的值传递。 这样,当用户访问相应的路由时,对应的组件将会被动态加载并渲染。 希望这个例子能帮到你!如果有任何问题,请随时问我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值