【webpack转vite】操作流程与问题

博主分享了如何通过vite优化一个启动和热更新速度极慢的大型管理端项目的过程。详细记录了从全局安装wp2vite,项目配置,包括删除public目录下的index.html,修改引用,设置alias和proxy,处理require和path.resolve报错,到最终启动项目的步骤。改造后,启动和热更新速度显著提升。
	最近在开发一个超级大的管理端项目,每次启动都要在8、9分钟,热更新一次也需要40秒,十分折磨,试过很多提速方法,都没有效果;周二晚上看到了vite-下一代前端开发与构建工具,周三上班就开始从网上翻找教程,经历过无数bug,历经两天,终于解决,特此记录一下所有流程与踩坑经历

一、全局安装wp2vite

npm install -g wp2vite

二、在项目中执行一下命令

执行之前记得安装好依赖:npm install

wp2vite --config=./vue.config.js //你的webpack配置文件

执行完以上命令后再执行一遍:npm install
截止这一步,主要操作搞定

三、项目配置操作

1、删除原有public目录下的index.html文件

2、修改根目录下的index.html,引用自己的main.js文件

<script type="module" src="/src/main.ts"></script>

我的是ts,可自行修改

3、重点:vite.config.js

①设置alias,增加绝对路径@
let alias = {
    '.git': path.resolve(__dirname, './.git'),
    'docker': path.resolve(__dirname, './docker'),
    'docs': path.resolve(__dirname, './docs'),
    'node_modules': path.resolve(__dirname, './node_modules'),
    'public': path.resolve(__dirname, './public'),
    'src': path.resolve(__dirname, './src'),
    '@': path.resolve(__dirname, 'src'),
  }
②设置proxy,就是你的代理

在proxy对象中添加代理
代理
注意此时写法有变,将pathRewrite修改为rewrite,举个栗子

vue.config.js
	'/api': {
        target: `http://localhost:8180`,
        changeOrigin: true,
        ws: true,
        pathRewrite: {
          '^/api': '',
        },
      },
vite.config.js
'/api': {
      target: `http://localhost:8180`, 
      changeOrigin: true,
      ws: true,
      rewrite: (path) => path.replace(/^\/api/, '')
    },

4、require报错

如果你用到了require.context(),请替换为import.meta.globEager(),示范如下

const requires = require.context('@/modules', true, /router\.ts$/);//原有
const requires = import.meta.globEager("@/modules/*/router.ts")//修改后

5、path.resolve报错

先安装依赖

npm install path-browserify --save

修改引入方式为

import path from 'path-browserify'

四、启动项目

npm run dev

五、速度比较

启动速度

vite

vite启动

webpack
实在太慢,不想截图了

热更新速度

biu~bang //超级快

录了视频,但是要转成gif,不想转,改vue页面改完就能生效,都不用刷新页面;改ts文件也是立刻生效,会自动刷新页面

完结撒花

WebpackVite 是现代前端开发中常用的构建工具,它们在核心机制、性能表现、配置灵活性以及适用场景等方面各有特点。 ### 构建模式核心机制 Webpack 采用打包器模式,在开发环境和生产环境均会对整个项目进行打包处理。冷启动时,Webpack 会遍历所有模块依赖并生成最终的 Bundle 文件。这一过程会消耗较多时间,尤其在大型项目中更为明显[^2]。 相比之下,Vite 利用浏览器原生支持的 ES Modules,在开发环境中跳过了打包过程,采用按需编译的方式。只有在浏览器请求某个模块时,Vite 才会实时编译该模块并返回结果。这种方式显著提升了开发服务器的启动速度和热更新效率[^2]。 ### 性能对比 在冷启动速度方面,Webpack 相对较慢,因为其需要全量扫描和打包依赖,而 Vite 仅需编译入口文件即可启动开发服务器,因此启动速度极快[^2]。 在热更新(HMR)方面,Webpack 的更新速度取决于 Bundle 的大小,而 Vite 的按需编译机制使其热更新速度达到毫秒级别,响应更加迅速[^2]。 在生产构建方面,Webpack 有着成熟的构建流程和优化机制,如 Tree Shaking、代码分割等,适合复杂的构建需求。而 Vite 在生产环境中使用 Rollup 进行打包,虽然构建速度快,但其生态相比 Webpack 略显薄弱[^3]。 ### 配置扩展性 Webpack 的配置较为复杂,需要手动处理 Loader 和 Plugin,但这也带来了更高的灵活性和定制化能力。它拥有庞大的插件生态,适用于各种复杂场景,如微前端架构等[^2]。 Vite 提供了开箱即用的体验,默认支持 TypeScript、CSS 预处理器等,简化了配置流程。虽然其插件生态还在快速增长中,但已经能够兼容部分 Rollup 插件,逐步完善中[^2]。 ### 适用场景 Webpack 更适合大型传统项目、需要兼容旧浏览器的项目以及需要复杂自定义构建流程的场景。对于追求极速开发体验的轻量项目,Vite 是更好的选择。Vite 特别适合现代浏览器项目(如使用 Vue/React 技术栈)或快速原型开发[^2]。 ### 总结选型建议 如果开发效率是首要考虑因素,尤其是新项目或基于现代框架(如 Vue 3 或 React)的项目,Vite 是理想的选择。而 Webpack 在需要深度定制构建流程或需要兼容旧系统的情况下更为合适。对于大型项目,也可以采用折中方案,即在开发环境中使用 Vite 提升效率,在生产环境中使用 Webpack 保证构建质量[^2]。 ```javascript // 示例:Vite 的简单配置文件 vite.config.js import { defineConfig } from 'vite'; import vue from '@vitejs/plugin-vue'; export default defineConfig({ plugins: [vue()], }); ``` ```javascript // 示例:Webpack 的简单配置文件 webpack.config.js const path = require('path'); module.exports = { entry: './src/index.js', output: { filename: 'bundle.js', path: path.resolve(__dirname, 'dist'), }, module: { rules: [ { test: /\.js$/, loader: 'babel-loader', exclude: /node_modules/, }, ], }, }; ```
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值