Vite
- Webpack是目前整个前端使用最多的构建工具,但是除了webpack之后也有其他的一些构建工具
- 比如rollup、parcel、gulp、vite等等
- 什么是vite呢? 官方的定位:下一代前端开发与构建工具
- 如何定义下一代开发和构建工具呢
- 我们知道在实际开发中,我们编写的代码往往是不能被浏览器直接识别的,比如ES6、TypeScript、Vue文件等 等
- 所以我们必须通过构建工具来对代码进行转换、编译,类似的工具有webpack、rollup、parcel
- 但是随着项目越来越大,需要处理的JavaScript呈指数级增长,模块越来越多
- 构建工具需要很长的时间才能开启服务器,HMR也需要几秒钟才能在浏览器反应出来
- 所以也有这样的说法:天下苦webpack久矣
- Vite (法语意为 “快速的”,发音 /vit/) 是一种新型前端构建工具,能够显著提升前端开发体验
Vite的构造
- 它主要由两部分组成
- 一个开发服务器,它基于原生ES模块提供了丰富的内建功能,HMR的速度非常快速
- 一套构建指令,它使用rollup打开我们的代码,并且它是预配置的,可以输出生成环境的优化过的静态资源
Vite的安装和使用
npm install vite –g # 全局安装
npm install vite –D # 局部安装
- 注意:Vite本身也是依赖Node的,所以也需要安装好Node环境
- 并且Vite要求Node版本是大于12版本的
- 通过vite来启动项目
npx vite
Vite对css的支持
- vite可以直接支持css的处理
- 直接导入css即可
- vite可以直接支持css预处理器,比如less
- 直接导入less
- 之后安装less编译器
- vite直接支持postcss的转换
- 只需要安装postcss,并且配置 postcss.config.js 的配置文件即可 npm install postcss postcss-preset-env -D
module.exports = {
plugins: [
require('postcss-preset-env')
]
}
Vite对TypeScript的支持
- vite对TypeScript是原生支持的,它会直接使用ESBuild来完成编译
- 只需要直接导入即可
- 如果我们查看浏览器中的请求,会发现请求的依然是ts的代码
- 这是因为vite中的服务器Connect会对我们的请求进行转发
- 获取ts编译后的代码,给浏览器返回,浏览器可以直接进行解析
- 注意:在vite2中,已经不再使用Koa了,而是使用Connect来搭建的服务器
Vite对vue的支持
-
vite对vue提供第一优先级支持
- Vue 3 单文件组件支持:@vitejs/plugin-vue
- Vue 3 JSX 支持:@vitejs/plugin-vue-jsx
- Vue 2 支持:underfin/vite-plugin-vue2
-
安装支持vue的插件
npm install @vitejs/plugin-vue -D
- 在vite.config.js中配置插件
import vue from '@vitejs/plugin-vue'
module.exports = {
plugins: [
vue()
]
}
Vite打包项目
- 我们可以直接通过vite build来完成对当前项目的打包工具
npx vite build
- 我们可以通过preview的方式,开启一个本地服务来预览打包后的效果
npx vite preview
ESBuild解析
- ESBuild的特点
- 超快的构建速度,并且不需要缓存
- 支持ES6和CommonJS的模块化
- 支持ES6的Tree Shaking
- 支持Go、JavaScript的API
- 支持TypeScript、JSX等语法编译
- 支持SourceMap
- 支持代码压缩
- 支持扩展其他插件
ESBuild的构建速度
- ESBuild的构建速度和其他构建工具速度对比
- ESBuild为什么这么快呢
- 使用Go语言编写的,可以直接转换成机器代码,而无需经过字节码
- ESBuild可以充分利用CPU的多内核,尽可能让它们饱和运行
- ESBuild的所有内容都是从零开始编写的,而不是使用第三方,所以从一开始就可以考虑各种性能问题
Vite脚手架工具
- Vite的两个工具
- vite:相当于是一个构件工具,类似于webpack、rollup
- @vitejs/create-app:类似vue-cli、create-react-app
- 脚手架工具使用
npm init @vitejs/app
或者
// 上面的做法相当于省略了安装脚手架的过程
npm install @vitejs/create-app -g
create-app