react-router-dom之异步加载路由方式
react-router-dom异步加载路由
这篇文章跟https://www.jb51.net/article/278887.htm衔接
在一个spa单页面应用中如果项目较小的话异步组件可能影响不大,但是如果是一个大的react单页面项目如果没有使用异步组件,页面会在第一次加载的时候加载所有项目中所有的组件严重影响页面的加载速度,异步组件可以让路由跳转到对应的路由上才去加载对应的react文件,这样页面的加载速度就会得到很大的提升。因此异步组件是非常有必要的。
先来看看异步组件是怎么写的吧
安装依赖react-loadable
npm install react-loadable
新建一个js文件。异步组件也是要依赖于react所以要引入react。
意思大概就是在loader引入组件完成前先显示“正在加载”
//入口文件中不在调用之前的RouterTest组件而是调用这个异步组件 //获取路由参数的方法需要进行调整要在对应的再组件中调用react-router-dom中的withRouter方法 //然后export default connect(null,null)(withRouter(RouterTest)) import React from 'react' import Loadable from 'react-loadable' const LoadingRouterTest = Loadable({ loader:() => import('./RouterTest.js'), loading () {return <div>正在加载</div>} }) export default () => <LoadingRouterTest />
既然用了异步组件其他几个地方就要做相应的改动。首先是入口文件
我们将RouterTest替换成LoadingRouterTest这个组件
<Route path="/LoadingRouterTest:id" component={LoadingRouterTest}></Route> <Route path="/RouterTest:id" component={RouterTest}></Route>
我们跳转也是跳转LoadingRouterTest这个路由url变成这样,但是页面还是RouterTest。
这里会发现一个问题就是路由的参数获取不到了
原因是因为url名称变了但是页面还是RouterTest
这里需要用到react-router-dom的withRouter
在暴露RouterTest组件的时候使用withRouter这个方法允许RouterTest使用LoadingRouterTest的url参数
export default connect(null,null)(withRouter(RouterTest))
个人认为react-router-dom相对vue-router还是比较复杂的不管是传参还是异步组件,但是可操作的空间还是有的。
react路由组件异步加载,优化白屏
//手写异步加载高阶组件 import React, { Component } from "react"; export default function asyncComponent(importComponent) { class AsyncComponent extends Component { constructor(props) { super(props); this.state = { component: null }; } async componentDidMount() { const { default: component } = await importComponent(); this.setState({component}); } render() { const C = this.state.component; return C ? <C {...this.props} /> : null; } } return AsyncComponent; }
import React, { Component } from 'react'; import { HashRouter, Switch, Route, Redirect } from 'react-router-dom'; import asyncComponent from '@/utils/asyncComponent'; import home from "@/pages/home/home"; const record = asyncComponent(() => import("@/pages/record/record")); const helpcenter = asyncComponent(() => import("@/pages/helpcenter/helpcenter")); const production = asyncComponent(() => import("@/pages/production/production")); const balance = asyncComponent(() => import("@/pages/balance/balance")); // react-router4 不再推荐将所有路由规则放在同一个地方集中式路由,子路由应该由父组件动态配置,组件在哪里匹配就在哪里渲染,更加灵活 export default class RouteConfig extends Component{ render(){ return( <HashRouter> <Switch> <Route path="/" exact component={home} /> <Route path="/record" component={record} /> <Route path="/helpcenter" component={helpcenter} /> <Route path="/production" component={production} /> <Route path="/balance" component={balance} /> <Redirect to="/" /> </Switch> </HashRouter> ) } }
/**注解 * 路由表中: * const record = asyncComponent(() => import("@/pages/record/record")); * <Route path="/record" component={record} /> * -------------------------------------------------------------- * >>1 * asyncComponent函数返回了一个组件AsyncComponent,AsyncComponent被record变量接收; * asyncComponent函数参数是一个()=>import('xxx')方法,该方法是用来引入文件的,返回的的是一个promise对象。 * >>2 * 当react路由匹配到对应路径,AsyncComponent组件挂在,参数()=>import('xxx')方法在其挂在后执行,将异步加载的组件更改到状态,并再次重新渲染。 */
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
React教程之Props验证的具体用法(Props Validation)
这篇文章主要介绍了React教程之Props验证的具体用法(Props Validation),非常具有实用价值,需要的朋友可以参考下2017-09-09react-router-dom入门使用教程(前端路由原理)
这篇文章主要介绍了react-router-dom入门使用教程,主要包括react路由相关理解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-08-08React Router中Link和NavLink的学习心得总结
这篇文章主要介绍了React Router中Link和NavLink的学习心得总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-12-12React Hooks与setInterval的踩坑问题小结
本文主要介绍了React Hooks与setInterval的踩坑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-04-04
最新评论