vite学习笔记

Vite(法语意为"快速")是新一代前端构建工具,由 Vue.js 创始人尤雨溪开发,具有以下核心特性:

极速启动:冷启动时间比传统工具快 10-100 倍

闪电热更新:HMR 更新速度不受项目规模影响

智能构建:生产环境使用 Rollup 打包

原生 ESM:基于浏览器原生 ES 模块系统

与传统打包工具对比

特性 Webpack Vite
启动机制 全量打包 按需编译
模块系统 模拟 CommonJS 原生 ESM
HMR 效率 线性增长 恒定时间
构建工具 自研打包 Rollup
开发服务器 内存文件系统 真实文件系统

技术栈支持

技术 支持方式 示例配置
Vue 官方插件 @vitejs/plugin-vue
React 官方插件 @vitejs/plugin-react
TypeScript 原生支持 零配置
CSS 预处理器 内置支持 .scss/.less 直接导入
静态资源 智能处理 自动路径处理

快速开始:

创建项目

npm create vite@latest my-project -- --template vue-ts

目录结构

my-project/
├── node_modules
├── src/
│ ├── main.ts
│ ├── App.vue
│ └── ...
├── index.html
├── vite.config.ts
└── package.json

javascript 复制代码
// vite.config.ts
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

export default defineConfig({
  plugins: [vue()],
  resolve: {
    alias: {
      '@': '/src'
    }
  },
  server: {
    proxy: {
      '/api': {
        target: 'http://localhost:3000',
        changeOrigin: true
      }
    }
  },
  build: {
    rollupOptions: {
      output: {
        manualChunks: {
          lodash: ['lodash-es']
        }
      }
    }
  }
})

性能优化:

构建优化策略

优化方向 实现方案 配置示例
依赖预构建 optimizeDeps 配置 optimizeDeps: { include: ['lodash-es'] }
代码分割 动态 import + rollup 配置 manualChunks 配置
图片压缩 vite-plugin-imagemin 自动 PNG/JPG 优化
Gzip 压缩 vite-plugin-compression 预生成压缩文件

加载优化方案

// 典型配置组合
export default defineConfig({
build: {
cssCodeSplit: true,
assetsInlineLimit: 4096, // 4KB以下资源内联
sourcemap: 'hidden',
minify: 'terser'
}
})

推荐使用场景

  1. 现代浏览器项目(Chrome >=61, Firefox >=60, Safari >=11)

  2. 框架新项目(Vue3/React18/Svelte)

  3. 库开发(利用 Rollup 的纯净打包)

  4. 微前端子应用(快速加载需求)

暂不推荐场景

  1. 需要支持 IE11 的项目

  2. 已有复杂 Webpack 配置的大型项目

  3. 需要深度自定义构建流程的特殊需求

相关推荐
芝士不会写代码4 小时前
【FPGA学习】DE2-115实现LED流水灯
学习·fpga开发
西岭千秋雪_4 小时前
计算机网络学习笔记:TCP可靠传输实现、超时重传时间选择
网络·笔记·学习·tcp/ip·计算机网络
小开心大王4 小时前
嵌入式学习笔记——day36-多路IO复用
笔记·学习
Wilber的技术分享4 小时前
【机器学习实战笔记 12】集成学习:AdaBoost算法
人工智能·笔记·算法·决策树·机器学习·分类·集成学习
炽天使3285 小时前
Git 日常操作流程(备查)
git·学习
唐人街都是苦瓜脸5 小时前
学习Oracle------高可用架构解析
学习·oracle·架构
mooyuan天天5 小时前
pikachu靶场通关笔记40 反序列化(三种方法渗透)
笔记·安全·web安全·反序列化漏洞·pikachu靶场
缘友一世6 小时前
创业知识概论
经验分享·笔记·职场和发展·创业创新
全栈小57 小时前
【数据库】在线体验KingbaseES平台,零门槛学习,并快速体验Oracle增改查全基础功能
数据库·学习·oracle
来两个炸鸡腿7 小时前
【Datawhale组队学习202506】YOLO-Master task02 YOLO系列发展线
python·深度学习·学习·yolo