Migración desde v3
Rollup 3
Vite ahora usa Rollup 3, lo que nos permitió simplificar el manejo interno de recursos de Vite y tiene muchas mejoras. Consulta las notas de la versión de Rollup 3 aquí.
Rollup 3 es mayormente compatible con Rollup 2. Si usas opciones de rollupOptions
personalizadas en tu proyecto y encuentras problemas, consulta la guía de migración de Rollup para actualizar la configuración.
Cambio de línea de base en navegadores modernos
La compilación para navegadores modernos ahora apunta a safari14
de forma predeterminada para una mayor compatibilidad con ES2020. Esto significa que las compilaciones para navegadores modernos ahora pueden usar BigInt
y que el operador coalescente nulo ya no se transpile. Si necesitas soportar navegadores más antiguos, puedes agregar @vitejs/plugin-legacy
como de costumbre.
Cambios generales
Codificación
El juego de caracteres predeterminado de compilación ahora es utf8 (consulta #10753 para obtener más detalles).
Importando CSS como String
En Vite 3, importar la exportación predeterminada de un archivo .css
podría generar una doble carga de CSS.
import cssString from './global.css'
Esta carga doble podría ocurrir ya que se emitirá un archivo .css
y es probable que el código de la aplicación también use la cadena CSS, por ejemplo, inyectada por el tiempo de ejecución del marco. A partir de Vite 4, la exportación predeterminada .css
ha quedado obsoleta. El modificador de sufijo de consulta ?inline
debe usarse en este caso, ya que no emite los estilos .css
importados.
import stuff from './global.css?inline'
Compilaciones para producción por defecto
vite build
ahora siempre compilará para producción independientemente del --mode
invocado. Anteriormente, cambiar el mode
a otro que no sea production
daría como resultado una compilación de desarrollo. Si aún deseas compilar para desarrollo, puedes configurar NODE_ENV=development
en el archivo .env.{mode}
.
Como parte de este cambio, vite dev
y vite build
ya no se sobrepondrán a process.env.NODE_ENV
si ya está definido. Luego, si se configuró process.env.NODE_ENV = 'development'
antes de compilar, también compilará para desarrollo. Esto brinda más control cuando se ejecutan múltiples compilaciones o servidores de desarrollo en paralelo.
Consulta la documentación actualizada de mode
para obtener más detalles.
Variables de entorno
Vite ahora usa dotenv
16 y dotenv-expand
9 (anteriormente dotenv
14 y dotenv-expand
5). Si tienes un valor que incluye #
o `
, deberás incluirlos entre comillas.
-VITE_APP=ab#cd`ef
+VITE_APP="ab#cd`ef"
Para obtener más detalles, consulta dotenv
y dotenv-expand
changelog.
Avanzado
Hay algunos cambios que solo afectan a los creadores de complementos/herramientas.
- [#11036] feat(client)!: remove never implemented hot.decline
- Usa
hot.invalidate
su lugar
- Usa
- [#9669] feat: align object interface for
transformIndexHtml
hook- Usa
order
en vez deenforce
- Usa
También hay otros cambios importantes que solo afectan a unos pocos usuarios.
- [#11101] feat(ssr)!: remove dedupe and mode support for CJS
- Debes migrar al modo ESM predeterminado en SSR, la compatibilidad con CJS en SSR puede eliminarse en la próxima versión mayor de Vite.
- [#10475] feat: handle static assets in case-sensitive manner
- Tu proyecto no debe depender de un sistema operativo que ignore las mayúsculas y minúsculas de los nombres de archivo.
- [#10996] fix!: make
NODE_ENV
more predictable- Consulta esta solicitud para obtener una explicación sobre este cambio.
- [#10903] refactor(types)!: remove facade type files
Migración desde v2
Consulta la Guía de migración desde v2 en la documentación de Vite v3 primero para ver los cambios necesarios para migrar tu aplicación a Vite v3 y luego continuar con los cambios descritos en esta página.