빌드 옵션
build.target
- 타입:
string | string[]
- 기본값:
'modules'
- 관련 항목: 브라우저 지원 현황
최종 번들을 위한 브라우저 호환성 타깃입니다. 기본값은 Vite에서만 사용 가능한 'modules'
이며, 네이티브 ES 모듈, 네이티브 ESM의 동적 Import, 그리고 import.meta
를 지원하는 브라우저를 타깃으로 합니다. 즉, Vite는 'modules'
를 ['es2020', 'edge88', 'firefox78', 'chrome87', 'safari14']
로 대체합니다.
또 다른 특수 값은 'esnext'
입니다. 이는 네이티브 동적 가져오기가 지원되는 것으로 가정하고 가능한 한 적게 트랜스파일 됩니다:
build.minify
옵션이'terser'
이고 설치된 Terser 버전이 5.16.0 미만인 경우,'esnext'
는'es2021'
로 강제 설정됩니다.- 다른 경우에는, 전혀 트랜스파일이 수행되지 않습니다.
변환은 esbuild로 수행되며, 값은 유효한 esbuild 타깃 옵션이어야 합니다. 사용자 지정 타깃은 ES 버전 (예: es2015
)이나 버전이 있는 브라우저 (예: chrome58
) 또는 다중 타깃 문자열의 배열이 될 수 있습니다.
코드안에 esbuild로 안전하게 트랜스파일 할 수 없는 기능이 포함된 경우 빌드는 실패할 것입니다. 자세한 점은 esbuild 문서를 확인하세요.
build.modulePreload
- 타입:
boolean | { polyfill?: boolean, resolveDependencies?: ResolveModulePreloadDependenciesFn }
- 기본값:
{ polyfill: true }
기본적으로, 모듈 사전로드 폴리필이 자동으로 주입됩니다. 폴리필은 각 index.html
엔트리의 프락시 모듈에 자동 주입됩니다. 빌드가 build.rollupOptions.input
을 통해 HTML이 아닌 커스텀 엔트리를 사용하도록 설정된 경우, 커스텀 엔트리에 직접 폴리필을 가져와야 합니다:
import 'vite/modulepreload-polyfill'
참고: 폴리필은 라이브러리 모드에 적용되지 않습니다. 네이티브 동적 가져오기 없이 브라우저를 지원해야 한다면, 아마도 라이브러리에서 이것을 사용하지 않는 것이 좋습니다.
폴리필은 { polyfill: false }
를 사용하여 비활성 할 수 있습니다.
각 동적 가져오기를 위한 사전 로드되는 청크 목록은 Vite에서 산출합니다. 기본적으로, 이러한 디펜던시를 로드할 때 base
를 포함하는 하나의 절대경로가 사용됩니다. base
가 상대적인 경우 (''
or './'
), 절대 경로가 최종 배포되는 base에 의존하지 않도록 import.meta.url
이 런타임에 사용됩니다.
디펜던시 목록 및 그 경로에 대한 세밀한 제어를 위해 resolveDependencies
함수를 사용한 실험적인 지원사항이 있습니다. 이 곳에 피드백을 남겨주세요. ResolveModulePreloadDependenciesFn
유형의 함수가 그것입니다:
type ResolveModulePreloadDependenciesFn = (
url: string,
deps: string[],
context: {
importer: string
}
) => string[]
resolveDependencies
함수는 종속된 청크 목록과 함께 각 동적 가져오기를 위해 호출되며, 또한 엔트리 HTML 파일 상에 가져와진 각 청크를 위해 호출됩니다. 필터링되었거나 더 많은 디펜던시가 주입되었거나 경로가 수정되면 새로운 디펜던시 배열이 반환될 수 있습니다. deps
경로는 build.outDir
에 상대적입니다. hostType === 'js'
를 위해 hostId
로 상대 경로를 반환하는 것이 허용되며, 이 경우 HTML 헤드에서 해당 모듈 사전로드를 주입할 때 절대 경로를 가져오기 위해 new URL(dep, import.meta.url)
이 사용됩니다.
modulePreload: {
resolveDependencies: (filename, deps, { hostId, hostType }) => {
return deps.filter(condition)
},
},
결정된 디펜던시 경로는 experimental.renderBuiltUrl
를 사용하여 추가로 수정될 수 있습니다.
build.polyfillModulePreload
- 타입:
boolean
- 기본값:
true
- 사용 중단
build.modulePreload.polyfill
을 사용하세요.
module preload polyfill을 자동으로 주입할지 여부입니다.
build.outDir
- 타입:
string
- 기본값:
dist
(프로젝트 루트에 상대적인) 출력 디렉터리를 지정합니다.
build.assetsDir
- 타입:
string
- 기본값:
assets
생성된 에셋을 (build.outDir
에 상대적으로) 저장할 디렉터리를 지정합니다. 라이브러리 모드에서는 사용되지 않습니다.
build.assetsInlineLimit
- 타입:
number
|((filePath: string, content: Buffer) => boolean | undefined)
- 기본값:
4096
(4KiB)
이 값보다 작은 크기로 import 되거나 참조된 에셋은 부가적인 http 요청을 피하고자 base64 URL로 인라인 처리됩니다. 만일 인라인 변환을 사용하지 않으려면 0
으로 설정하세요.
콜백이 전달되면, boolean을 반환하여 opt-in 또는 opt-out 할 수 있습니다(여기서 opt-in은 인라인을, opt-out은 기본값을 사용합니다. 자세한 구현 사항은 커밋을 참고해 주세요. - 옮긴이). 반환되는 값이 없으면 기본 로직이 적용됩니다.
Git LFS(Large File Storage) 자리 표시자는 해당 파일의 내용을 포함하고 있지 않기에 인라인에서는 자동으로 제외됩니다.
참고
build.lib
를 지정하면 build.assetsInlineLimit
는 무시되며 파일 크기나 Git LFS 자리 표시자와 관계없이 에셋이 항상 인라인 처리됩니다.
build.cssCodeSplit
- 타입:
boolean
- 기본값:
true
CSS 코드 분할을 활성화/비활성화합니다. 활성화된 경우 비동기 JS 청크로 가져온 CSS 코드가 청크로 유지되고, 이후 청크를 가져올 때 함께 가져오게 됩니다.
비활성화된 경우, 전체 프로젝트의 모든 CSS가 단일 CSS 파일로 추출됩니다.
참고
만약 build.lib
으로 지정하게 되면, build.cssCodeSplit
이 기본적으로 false
가 됩니다.
build.cssTarget
- 타입:
string | string[]
- 기본값:
build.target
과 동일
이 옵션을 사용하면 CSS 축소 시 타깃이 되는 브라우저를 설정할 수 있습니다.
일반적으로 비주류 브라우저를 대상으로 하는 경우에만 사용되며, Android WeChat WebView를 예로 들 수 있습니다. 이 브라우저는 대부분의 최신 JavaScript 문법을 지원하지만 16진수 CSS 색상 표기법인 #RGBA
를 지원하지 않습니다. 이 경우, Vite가 rgba()
색상을 #RGBA
16진수 표기법으로 변환하는 것을 방지하기 위해 build.cssTarget
을 chrome61
로 설정해줘야 합니다.
build.cssMinify
- 타입:
boolean | 'esbuild' | 'lightningcss'
- 기본값:
build.minify
와 동일
이 옵션을 사용하면 기본값이 build.minify
로 설정되는 대신 CSS 축소화를 구체적으로 재정의할 수 있으므로, JS와 CSS를 별도로 축소화할 수 있습니다. Vite는 기본적으로 esbuild
를 사용해 CSS를 축소화하지만, 옵션을 'lightningcss'
로 설정하면 Lightning CSS를 사용할 수도 있습니다. 이를 선택한 경우, css.lightningcss
를 통해 설정이 가능합니다.
build.sourcemap
- 타입:
boolean | 'inline' | 'hidden'
- 기본값:
false
프로덕션에서 소스 맵을 생성합니다. true
인 경우 별도의 소스 맵 파일이 생성됩니다. 'inline'
인 경우 소스 맵이 결과 출력 파일에 데이터 URI로 추가됩니다. 'hidden'
은 번들 파일의 해당 소스 맵 설명이 표시되지 않는 경우를 제외하고 true
와 같이 작동합니다.
build.rollupOptions
- 타입:
RollupOptions
기존 Rollup 번들을 커스텀합니다. 이는 Rollup 설정 파일에서 내보낼 수 있는 옵션과 같으며 Vite의 내부 Rollup 옵션과 병합됩니다. 더 자세한 점은 Rollup 옵션 문서를 참고하세요.
build.commonjsOptions
@rollup/plugin-commonjs에 전달할 옵션입니다.
build.dynamicImportVarsOptions
- 타입:
RollupDynamicImportVarsOptions
- 관련 항목: 동적 Import
@rollup/plugin-dynamic-import-vars에 전달할 옵션입니다.
build.lib
- 타입:
{ entry: string | string[] | { [entryAlias: string]: string }, name?: string, formats?: ('es' | 'cjs' | 'umd' | 'iife')[], fileName?: string | ((format: ModuleFormat, entryName: string) => string) }
- 관련 항목: 라이브러리 모드
라이브러리로 빌드합니다. 라이브러리에서 HTML을 진입점으로 사용할 수 없으므로, entry
가 필요합니다. name
은 노출된 전역 변수이며 formats
가 'umd'
또는 'iife'
일 때 필요합니다. formats
의 기본값은 ['es', 'umd']
이나, 여러 entry
가 존재하는 경우라면 ['es', 'cjs']
가 됩니다. fileName
은 패키지 파일 출력의 이름이며, 기본값은 package.json 파일의 name 옵션입니다. 이는 format
과 entryAlias
를 인수로 취하는 함수로도 정의될 수 있습니다.
build.manifest
- 타입:
boolean | string
- 기본값:
false
- 관련 항목: 백엔드 프레임워크와 함께 사용하기
true
로 설정하면, 빌드는 해시되지 않은 에셋 파일 이름을 해시된 버전으로의 매핑이 포함된 .vite/manifest.json
파일도 생성합니다. 이 파일은 서버 프레임워크에서 올바른 에셋 링크를 렌더링하는 데 사용할 수 있습니다. 문자열 타입의 값은 매니페스트 파일의 이름으로 사용됩니다.
build.ssrManifest
- 타입:
boolean | string
- 기본값:
false
- 관련 항목: 서버 측 렌더링
true
로 설정하면, 빌드는 스타일 링크와 사전 로드된 에셋 디렉티브를 결정하기 위한 SSR 매니페스트 파일을 생성합니다. 문자열 타입의 값은 매니페스트 파일의 이름으로 사용됩니다.
build.ssr
- 타입:
boolean | string
- 기본값:
false
- 관련 항목: 서버 측 렌더링
서버 측 렌더링으로 빌드합니다. 설정 값은 SSR 항목을 직접 지정하는 문자열이거나, rollupOptions.input
을 통해 SSR 항목을 지정해야 하는 true
가 될 수 있습니다.
build.ssrEmitAssets
- 타입:
boolean
- 기본값:
false
SSR 빌드 중에는 정적 에셋이 따로 생성되지 않는데, 이는 클라이언트 빌드의 일부에 포함될 것으로 간주하기 때문입니다. 다만 필요한 경우 이 옵션을 사용하여 클라이언트와 SSR 빌드 모두에서 에셋을 생성하도록 강제할 수 있습니다. 이 경우 프레임워크는 빌드 이후 단계에서 에셋을 병합하는 것이 필요합니다.
build.minify
- 타입:
boolean | 'terser' | 'esbuild'
- 기본값: 클라이언트 빌드에는
'esbuild'
를, SSR 빌드에는false
를 사용
코드 경량화를 사용하지 않으려면 false
로 설정하거나, 사용할 코드 경량화 도구를 지정하세요. 기본값은 Esbuild로, Terser보다 20에서 40배가량 빠르며 압축률 또한 1 ~ 2%밖에 떨어지지 않습니다.
참고로 build.minify
옵션은 'es'
를 사용하는 라이브러리 모드에서 공백을 축소화하지 않습니다. 이는 Pure 애노테이션(@__PURE__
)을 제거하고, 또 트리 셰이킹을 제대로 동작하지 못하게 만들기 때문입니다.
'terser'
로 설정할 경우, Terser를 설치해야 합니다.
npm add -D terser
build.terserOptions
- 타입:
TerserOptions
Terser로 전달할 추가적인 경량화 옵션입니다.
maxWorkers: number
옵션을 전달하여 생성할 최대 워커 수를 지정할 수도 있습니다. 기본값은 CPU 수에서 1을 뺀 값입니다.
build.write
- 타입:
boolean
- 기본값:
true
번들을 생성할 때 디스크에 기록하지 않으려면 false
로 설정하세요. 이것은 디스크에 쓰기 전에 번들의 추가 후처리가 필요한 프로그래밍 방식 build()
호출에서 주로 사용됩니다.
build.emptyOutDir
- 타입:
boolean
- 기본값:
outDir
이root
안에 있다면true
기본적으로 Vite는 outDir
이 프로젝트 루트 내부에 있는 경우 빌드할 때 이 곳을 비웁니다. outDir
가 루트 외부에 있으면 실수로 중요한 파일을 제거하지 않도록 경고 메시지가 표시됩니다. 경고를 표시하지 않도록 이 옵션을 명시적으로 설정할 수 있습니다. 명령 줄에서는 --emptyOutDir
로 이를 사용할 수 있습니다.
build.copyPublicDir
- 타입:
boolean
- 기본값:
true
기본적으로 Vite는 빌드할 때 publicDir
에서 outDir
로 파일을 복사합니다. 이를 비활성화하려면 false
로 설정하세요.
build.reportCompressedSize
- 타입:
boolean
- 기본값:
true
gzip 압축 크기 보고를 활성화/비활성화합니다. 큰 출력 파일을 압축하는 경우 속도가 느릴 수 있으므로, 이를 사용하지 않도록 설정하면 대규모 프로젝트의 빌드 성능이 향상될 수 있습니다.
build.chunkSizeWarningLimit
- 타입:
number
- 기본값:
500
경고를 표시할 청크 크기의 경계(단위: kB). 자바스크립트 크기 자체가 실행 시간과 관련이 있기 때문에, 압축되지 않은 청크 크기를 기준으로 비교합니다.
build.watch
- 타입:
WatcherOptions
| null
- 기본값:
null
Rollup 감시자를 사용하려면 {}
로 설정하세요. 이는 대부분 빌드 전용 플러그인 또는 통합 프로세스를 포함하는 경우에 사용됩니다.
Windows Subsystem for Linux (WSL) 2 에서 Vite 사용하기
파일 시스템 변경사항 감시가 WSL2에서 동작하지 않는 경우가 있습니다. 자세한 사항은 server.watch
를 참고해주세요.