-
코드 스플리팅(Code Splitting) 코드 스플리팅은 애플리케이션의 번들을 작은 청크로 분리하여 초기 페이지 로드 시간을 줄여줍니다. Parcel은 자동으로 코드 스플리팅을 지원하므로, 추가적인 설정 없이도 최적의 번들링을 수행할 수 있습니다. 하지만, 필요에 따라 동적 임포트(Dynamic Import)를 사용하여 스플리팅을 수동으로 제어할 수도 있습니다.
-
트리 쉐이킹(Tree Shaking) 트리 쉐이킹은 사용되지 않는 코드를 제거하여 번들의 크기를 줄입니다. Parcel은 자동으로 트리 쉐이킹을 수행하므로, 사용되지 않는 코드는 자동으로 제거됩니다. 그러나, 필요에 따라
package.json
파일의sideEffects
필드를 사용하여 특정 파일을 트리 쉐이킹에서 제외할 수도 있습니다. -
압축 및 최적화 Parcel은 자동으로 JavaScript, CSS, HTML 등의 리소스를 압축 및 최적화합니다. 이러한 기능을 통해 번들의 크기를 최소화하고 성능을 개선할 수 있습니다. 최적화 옵션을 수정하려면
.babelrc
,.postcssrc
,.browserslist
,.htmlnano
등의 설정 파일을 사용할 수 있습니다. -
캐싱 Parcel은 변경 사항을 모니터링하여 적절한 컨텐츠 전송 네트워크(CDN)에 캐시를 저장합니다. 이를 통해 사용자에게 더 빠른 로딩 속도를 제공할 수 있습니다. 개발 모드에서는 캐싱이 비활성화되지만, 프로덕션 모드에서는 자동으로 활성화됩니다.
-
환경 변수 Parcel은 환경 변수를 지원하여 개발 및 프로덕션 모드에서 다른 설정을 적용할 수 있습니다.
.env
파일을 사용하여 환경 변수를 설정할 수 있으며, 이를 통해 빌드 시점에서 동적으로 환경을 변경할 수 있습니다.
이외에도 Parcel은 여러 기능을 제공하고 있으며, 성능을 최적화하기 위해 추가적인 설정이나 플러그인을 사용할 수도 있습니다. Parcel의 공식 문서 및 커뮤니티 리소스를 참고하여 자세한 정보를 얻을 수 있습니다.
참고 자료:
- Parcel 공식 문서: https://parceljs.org/
- Parcel GitHub 저장소: https://github.com/parcel-bundler/parcel