vite为什么编译比webpack快

启动速度:Vite在启动时不需要打包,因为它支持ES模块加载,不需要编译和打包所有模块的依赖。这意味着Vite在启动时不需要像Webpack那样构建整个项目的文件,因此启动速度更快。

1 vite 采用 es 新规范

vite 中的 main.ts 中可以直接使用 import,不需要对此进行解析,不需要将 es6 转成 es5

JavaScript 复制代码
#vite 直接引入了 main.ts
<!DOCTYPE html>
<html lang="zh-CN">
  <body>
    <div id="app"></div>
    <script type="module" src="/src/main.ts"></script>
  </body>
</html>

#webpack 会将所有的文件编译打包成对应js文件,然后插入到 #app 节点后
<!DOCTYPE html>
<html lang="zh-cmn-Hans">
  <body>
    <div id="app"></div>
    <!--
    <script type="text/javascript" src="/static/js/chunk-vendors.js"></script>
    <script type="text/javascript" src="/static/js/app.js"></script>
    -->
  </body>
</html>

2 基于1,对于 node_modules 中的包文件,vite 会直接请求对应的文件

**xxx.js、xxx.vue **中遇到 import { xxx } from "包名",并且当包名不以 / ./ ../ 开头

会进行字符串转换,将包地址转换为以 /node_modules/.vite 开头的相对或绝对路径

JavaScript 复制代码
xxx.js 或 xxx.vue 转换后的路径
import { xxx } from "/node_modules/.vite/deps/vue.js?v=b3ae5e1f"
import _export_sfc from "/@id/__x00__plugin-vue:export-helper"


#控制台直接请求的路径
http://localhost:5183/node_modules/.vite/deps/moment.js?v=b3ae5e1f
http://localhost:5183/node_modules/.vite/deps/vue-router.js?v=b3ae5e1f
基于直接请求了node_modules中的文件,在编译过程中,也能够直接读取本地缓存(vite 有自己的策略,当包更新时,能够通过改变 xxx.js?v=xxx值的方式请求到最新文件)

3 对于非node_moduels中的部分需要编译的部分,比如 ts 语法,jsx 语,Vite采用按需加载的方式,当请求某个模块时才会对该模块进行编译。

  • Vite 将所有的文件,如 xx.vue 进行路径 hmlrId 值处理
  • vite 将 <script type="module" src="/@vite/client"></script> 置入到 html 页面顶部,开启 websocket监听,监听文件变化
  • 将文件变化后,遍历变化的文件,计算出要更新的模块,发送 socket 信息,触发对应模块 import.meta.hot.accept 函数
JavaScript 复制代码
# 消息列举
# /node_modules/.pnpm/vite@5.0.12/node_modules/vite/dist/client/env.mjs" 中的部分逻辑
# 目前很多时候发送的都是 full-reload,后面值得深究下

async function handleMessage(payload) {
    switch (payload.type) {
      case 'connected':
          break;
      case 'update':
          break;
      case 'custom':
          break;
      case 'full-reload':
          break;
      case 'prune':
          break;
      case 'error':
          break;
      default:
        break
    }
}
相关推荐
leafyyuki7 分钟前
前端 SSE 流式请求实战:打造流畅的 AI 流式应答体验
前端·人工智能·markdown
幸福指北15 分钟前
我用 Tauri + Vue 3 + Rust 开发了一款跨平台网络连接监控工具Portview,性能炸裂!
前端·网络·vue.js·tcp/ip·rust
炁场悟道16 分钟前
基于vue3的极简登录架构设计
前端
光影少年19 分钟前
Webpack的核心概念?常见优化手段?
前端·webpack·掘金·金石计划
han_20 分钟前
前端性能优化之白屏、卡顿指标和网络环境采集篇
前端·javascript·性能优化
Flyfreelylss29 分钟前
DOM 注入实践:在 React 中优雅地扩展第三方组件
前端·react.js
北城笑笑37 分钟前
Vue 100 ,Metaspace memory lack Error( 元空间内存不足 )
java·前端·javascript·vue
谏书稀38 分钟前
vue项目(pnpm)迁移到无网环境开发
前端·javascript·vue.js
Han.miracle43 分钟前
Spring IoC 与 DI 核心知识点综合测试题
java·前端·数据库
-杨豫1 小时前
JavaScript入门到精通全套资料,以及核心进阶ES6语法,API,js高级等基础知识和实战教程
开发语言·javascript·es6