使用webpack.require优化vue项目的路由

之前做一个后台系统的时候,前期路由也就十多个,就是使用的文档中的那种写法:

import Vue from 'vue';    

const Login = () => import('@/components/login/login');       
const Index = () => import('@/components/home/index');     
// balaba.......前期少量的路由                        
export default new Router({                                        
routes: [ 
    {                               
      path: '/login',                     
      name: 'Login',                   
      component: Login,                 
    },
    {                     
      path: '/home',                
      redirect: '/operation/info/list',                  
      name: 'home',
    },                      
    //babal..........前期少量的路由     
    ])         
复制代码

在后期需求越来越来之后,整个项目的页面达到了200+,此时的路由用之前的写法无疑显得特别冗余,且在团队协作的时候同时修改此文件容易冲突。

上图是项目后期部分路由对应文件的引入,此时的项目特别难以维护。为了解决这个问题,我们项目使用了webpack.require这个方法解决。 引用官方定义 使用 require.context() 方法来创建自己的上下文(模块)。 你可以给这个方法传3个参数:要搜索的文件夹目录,是否还应该搜索它的子目录,一个匹配文件的正则表达式。
既: require.context('../view',true,/\.(vue|js)$/),第一个参数指的是要检索的文件路径,第二个参数是指是否检索子目录,第三个参数需要传入一个正则表达式来匹配被检索目录下符合正则的文件(如上正则为匹配被检索目录所有vue/js文件)。
最终,我们的router.js从几百行的路由配置优文件化成了仅仅几十行代码的文件。
参考文章:https://github.com/wuchangming/blog/blob/master/docs/webpack/require-context-usage.md

转载于:https://juejin.im/post/5ab86990f265da238532d95e

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值