这篇文章主要介绍“React-router中怎么结合webpack实现按需加载”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“React-router中怎么结合webpack实现按需加载”文章能帮助大家解决问题。1.webpack的code splittingwebpack可以通过一些方法,来实现按需加载,暴露的接口为require.ensure这个require.ensure保证了模块的异步调用,当callback回调中调用了一个模块的时候,可以实现按需加载。2.React-router实现按需加载的接口React-router定义了 getChildRoutes, getIndexRout 香港云主机e, getComponents这样3个方法,这3个方法是异步的,并且只在需要的时候调用,通过这3个方法定义的路由,我们称之为“渐进式路由匹配”,React-router在匹配到路由时,只是渐进式的加载改路由所需要的组件,这样就能实现按需加载。(1)webpack的配置:在这里我们加上了chunkFilename:…. 这句代码用于分割js,特别注意publicPath这个路径要与服务器的资源的路径对应,否则加载js的时候会出现404错误。(2)通过getComponents等3个方法重新配置路由这里我们将路由定义中的component替换成了 getComponent。(3)最后效果:首页时候,加载了examine.js和nav.js:
切换路由时,比如从首页切换到了商品管理,这样除了加载examine.js外,多加载了admin.js:(4)总结:我们看到react-router的按需加载,作用主要表现在可以减少首页请求的文件的大小。3.注意事项:1、require(‘components/Index’).default中require方法的参数不能使用变量,只能使用字符串!2、如果你的组件是使用es5的module.exports导出的话,那么只需要require(‘components/Index’)即可。而如果你的组件是使用es6的export default导出的话,那么需要加上default!例如:require(‘components/Index’).default3、如果在路由页面使用了按需加载(require.ensure)加载路由级组件的方式,那么在其他地方(包括本页面)就不要再import了,否则不会打包生成chunk文件。简而言之,需要按需加载的路由级组件必须在路由页面进行加载。特别是第3点,笔者就是因为这个原因导致按需加载失败,特别注意import不能在任何地方引入按需加载的组件。
关于“React-router中怎么结合webpack实现按需加载”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注开发云行业资讯频道,小编每天都会为大家更新不同的知识点。
本篇内容介绍了“win7电脑磁盘清理提示检查不能执行如何解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!解决方法:1、按win+r打开运行窗口,输入“cmd”…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。