Skip to content

Beyond Fast

ViteConf 2023

Watch the replay!

v3에서 마이그레이션하기

Rollup 3

Vite는 이제 Rollup 3을 사용하며, Vite의 내부 에셋 처리를 단순화하고 많은 개선이 있습니다. 자세한 것은 Rollup 3 릴리스 노트를 참고해주세요.

Rollup 3는 많은 부분에서 Rollup 2와 호환됩니다. 만약 커스텀 rollupOptions를 사용하는 프로젝트에서 문제가 발생된다면, Rollup 마이그레이션 가이드를 참고하여 설정을 업그레이드하세요.

모던 브라우저 표준 변경

모던 브라우저 빌드는 이제 ES2020 호환성을 넓히기 위해 기본적으로 safari14를 대상으로 합니다. 이는 모던 빌드가 이제 BigInt를 사용할 수 있고 nullish coalescing operator가 더 이상 트랜스파일되지 않는다는 것을 의미합니다. 만약 이전 브라우저를 지원해야 한다면, @vitejs/plugin-legacy를 사용해주세요.

일반적인 변경사항

인코딩

빌드 시 이제 기본적으로 utf8을 사용합니다. 자세한 것은 #10753를 참고해주세요.

문자열로 CSS 가져오기

Vite 3에서, .css 파일의 default export를 가져오는 것은 CSS를 두 번 로드할 수 있습니다.

ts
import cssString from './global.css'

이 중복 로딩은 가져온 .css에 대한 스타일이 생성됨과 동시에 CSS 문자열이 애플리케이션 코드에서도 사용될 수 있기 때문에 발생할 수 있습니다(예를 들어, 프레임워크 런타임에 의해 주입될 수 있습니다). Vite 4부터 .cssdefault export사용이 중단되었으며, 이 대신 ?inline 쿼리 접미사 수정자를 사용해야 합니다. 이 경우에는 가져온 .css에 대해 스타일을 생성하지 않습니다.

ts
import stuff from './global.css?inline'

기본적으로 Production 빌드를 수행

vite build는 이제 전달된 --mode에 관계없이 항상 프로덕션 빌드를 수행합니다. 이전에는 modeproduction 이외의 다른 값으로 변경하면 개발 모드로 빌드가 수행되었습니다. 이제 개발 모드 빌드를 수행하려면 .env.{mode} 파일에서 NODE_ENV=development를 설정하면 됩니다.

이 변경 사항의 일부로, vite devvite build는 이미 정의된 경우 process.env.NODE_ENV를 더 이상 덮어쓰지 않습니다. 따라서 process.env.NODE_ENV = 'development'를 빌드하기 전에 설정했다면 개발 모드로 빌드할 수 있습니다. 이렇게 하면 여러 빌드 또는 병렬로 실행되는 개발 서버를 실행할 때 더 많은 제어를 할 수 있습니다.

더 자세한 정보는 모드 문서를 참조하세요.

환경 변수

Vite는 이제 dotenv 16과 dotenv-expand 9를 사용합니다(이전에는 dotenv 14와 dotenv-expand 5를 사용했습니다). # 또는 `를 포함하는 값이 있다면, 이 값을 따옴표로 감싸주세요.

diff
-VITE_APP=ab#cd`ef
+VITE_APP="ab#cd`ef"

자세한 내용은 dotenvdotenv-expand CHANGELOG를 참고해주세요.

고급

플러그인/툴 개발자에게만 영향을 미치는 변경사항이 있습니다.

다음은 많은 사용자에게 영향을 미치지 않는 변경사항입니다.

v2에서 마이그레이션하기

v2에서 마이그레이션하기 가이드를 먼저 확인하여 앱을 Vite v3로 포팅하기 위해 필요한 변경사항을 확인한 다음 이 페이지의 변경사항을 진행하세요.

Released under the MIT License.