前言
最近一直在看vite的源码(传送),恰逢公司的项目使用的是webpack,正好借此机会做下迁移,并将该过程记录。当前项目使用webpack+vue2
对比
这里挑选了一个比较复杂的路由页面,分别使用vite和webpack启动,记录从npm run start到页面加载的耗时
vite
data:image/s3,"s3://crabby-images/46424/46424f84d63be0682a7bac5ee6201e775b17927c" alt=""
webpack
data:image/s3,"s3://crabby-images/639cb/639cbdfae13b508ac84e901032c02ef620284b9a" alt=""
基础改造
package.json中新建指令
data:image/s3,"s3://crabby-images/f027a/f027a8711b0b3cd971f22c7d46e10699a81b91f2" alt=""
alias别名
和webpack一样,配置resolve.alias
data:image/s3,"s3://crabby-images/f414b/f414b92225fabdfa133147cf895aaa95e2dd05b1" alt=""
全局变量注入
使用vite内置的define代替webpack的DefinePlugin
data:image/s3,"s3://crabby-images/172c9/172c9d3aad8bb006268570a54eff348dd1f74460" alt=""
proxy代理
定义server.proxy代替webpack的proxyTable,写法上仅框红的一处不太一样
data:image/s3,"s3://crabby-images/2e64a/2e64aaa31a3836d25bb150ab9efa4b1ce30dcd3a" alt=""
适配vue2
yarn add vite-plugin-vue2,并在vite.config.js中引入并注册使用
data:image/s3,"s3://crabby-images/d7cda/d7cda845f08a87432d534cef8bd4049393d9fb64" alt=""
错误修复
白屏
报错
运行npm run dev:vite后打开浏览器,页面空白,可以看到入口的index.html中并没有引入script标签
data:image/s3,"s3://crabby-images/0a307/0a307b2370b987c052ee471d1f20f8a27174afa5" alt=""
修复
yarn add vite-plugin-html,并在vite.config.js中引入并注册使用,其entry配置项即可帮助我们自动注入script标签
data:image/s3,"s3://crabby-images/a9774/a97741176c9a4052d7a55c51dfad4b4e3cd875b6" alt=""
默认扩展名称
报错
不指定.vue扩展名称,会报如下错误
data:image/s3,"s3://crabby-images/39f11/39f11643fc20088a562e14f2a18f8017caa09d50" alt=""
点开该报错,感觉app并不是一个正常的文件
data:image/s3,"s3://crabby-images/a4adb/a4adb67098eb73e61427577a64f72af69d58e84c" alt=""
故找到引用处,尝试添加.vue扩展名后重启,报错如下
data:image/s3,"s3://crabby-images/62f93/62f939d1e20ede416999b9ceccbfad20837215e7" alt=""
修复
此时已经基本可以确定是省略扩展名称导致的了,故在resolve中增加如下配置
data:image/s3,"s3://crabby-images/bd519/bd5192432570133358bc176f51123093c0a5e1eb" alt=""
require语法报错
报错
data:image/s3,"s3://crabby-images/f0456/f04560d6f43eca99db7d39da8802a8daa08e870b" alt=""
修复
在webpack中能直接使用是因为其内部帮我们做了处理,在vite中需要单独引入插件(yarn add vite-plugin-require-transform)
data:image/s3,"s3://crabby-images/b7c17/b7c178843cdae7404794c7fb4976ee6a300c1e1e" alt=""
替换global
报错
data:image/s3,"s3://crabby-images/78f59/78f591d85e9c7df05af090d31ae9cf9038373be9" alt=""
修复
查看报错语句
data:image/s3,"s3://crabby-images/01c5d/01c5d73b3aa9875ae752ed450afd9d06a71211b7" alt=""
可以看到,其使用三元运算做了“降级处理”,理论上来说使用false的结果也问题不大
故,使用window来代替global
data:image/s3,"s3://crabby-images/f93eb/f93ebc0c73ff85ee41daeba1d898bffc9414c396" alt=""
修改vue引用版本
报错
data:image/s3,"s3://crabby-images/ecfa0/ecfa021f302c41a9cd4a91b7630d7ccac007683e" alt=""
修复
这是由于vue包中默认导出的是runtime版本,修改下之前定义的别名即可
data:image/s3,"s3://crabby-images/6dfc4/6dfc49f8679aed1a68ffa59daa026c77c13b620b" alt=""
依赖注入
报错
data:image/s3,"s3://crabby-images/27ac1/27ac12f213f6986c90a6003ba77816b749cae4da" alt=""
修复
在webpack中通过ProvidePlugin提前注入相关依赖而不需要在页面中显示引入,在vite中可以使用@rollup/plugin-inject来代替
data:image/s3,"s3://crabby-images/a2add/a2add38609f16479331c1e25158f8b2255f238df" alt=""
插件报错
报错
data:image/s3,"s3://crabby-images/d75dd/d75dd0b9c9df500af259719cfe183cd123725862" alt=""
修复
由于本次目的仅仅是为开发环境做改造,故为了尽可能少的影响生产,这里随便写个插件过滤下
data:image/s3,"s3://crabby-images/c1cbe/c1cbe2475a07dddf817618e3c02d18be8d1089df" alt=""
vite-plugin
报错
data:image/s3,"s3://crabby-images/10176/10176fe93fc128fb27303124fd4812b1e6a8368d" alt=""
修复
这是之前我优化面包屑时候写的webpack的loader,需要按照vite插件的语法格式做下替换,将直接export的方式改为返回一个包含name和transform的对象的函数即可
data:image/s3,"s3://crabby-images/7e97b/7e97b79c13391e609dc43ea9ef69c7f6693a28f4" alt=""
内置模块
报错
data:image/s3,"s3://crabby-images/3f781/3f781cbf030ce6395b5a0aa88fe40045b20d2884" alt=""
修复
项目中大量使用了node的timers模块的setTimeout方法,这在vite中被视为内置模块是不允许被客户端调用的,估计当初是不小心自动引入的,同样的,我们在插件中识别并替换掉
data:image/s3,"s3://crabby-images/d7975/d79758039df4eee0f52f9cbc668d75733927960e" alt=""
mqtt
报错如下
data:image/s3,"s3://crabby-images/8d52d/8d52db1549739951a040b9a475db8b23dddbd486" alt=""
查看相关代码,感觉是process相关的错误
data:image/s3,"s3://crabby-images/39f8a/39f8a45c82a3c0d86e3ef4a1d70b26d9f116a4ac" alt=""
故尝试安装process包,并通过inject进行注入
data:image/s3,"s3://crabby-images/4032d/4032d0257a2455f01cdbb83f8068504d7b596c79" alt=""
样式
错误
报错如下
data:image/s3,"s3://crabby-images/8aa73/8aa73aa5df3e6a6681ef52b98fdd3453d5c5eb8f" alt=""
修复
这是因为‘~’符号不被vite识别,因为该符号是vue-cli中的用法,去掉即可
data:image/s3,"s3://crabby-images/2a955/2a95536828cdb55abb64d167ecdac8e3031a944d" alt=""
icon失效
问题
data:image/s3,"s3://crabby-images/69391/6939160fd96657656e8b60ab8427a17362004639" alt=""
修复
在index.html中以cdn的当时引入,这虽然会对生产产生一定的影响,不过理论上其影响可以被忽略
data:image/s3,"s3://crabby-images/25195/25195c3e1a0df8a864859c0a787cf01d480d9845" alt=""
默认空格
问题
目前发现的,按钮直接的默认的空隙没了
data:image/s3,"s3://crabby-images/b6257/b62572153fc1b25965c4b5e3725f3c7376620c58" alt=""
修复
修改默认编译方式为preserve就可以了
data:image/s3,"s3://crabby-images/b6017/b6017972385f384ef5f6664927ad746b3cae87d4" alt=""
路由改造
由于vite本身就是按需加载的,则我们在路由中进行的懒加载就显得有点鸡肋,而且还会影响vite的预构建行为
data:image/s3,"s3://crabby-images/8254a/8254a2782824eaf4dc1ce04467672439f00985b7" alt=""
故考虑将路由引用方式做调整,同样出于仅作用于本地开发环境的考虑,需要在plugin阶段做下转换,即:
将如下引入方式
data:image/s3,"s3://crabby-images/842d6/842d63e3f6bf36e83f6dfae593e33e8d8c86244c" alt=""
通过plugin替换为如下形式
data:image/s3,"s3://crabby-images/98836/98836c3a56dbecb7f8308639b23d5ddb5caed2fc" alt=""
则随便写点正则
data:image/s3,"s3://crabby-images/60f4c/60f4c2719766e33a839c04e62188d026a43d2f6f" alt=""
替换结果如下
data:image/s3,"s3://crabby-images/78813/7881393fb31c17adf2e7d8892359e5d10ad34b9c" alt=""
取舍
这确实能有效避免二次预构建行为,也确实有效的提高了部分页面首次加载的时间,但是却导致首屏加载被拖到和webpack持平了,因此到底要不要改造路由方式就仁者见仁了.....