인프런 커뮤니티 질문&답변
배포 후 빈페이지
작성
·
117
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. SC님.
Vite 애플리케이션을 배포한 후에 “ReferenceError: require is not defined” 오류가 발생하는 문제는 CommonJS 방식의 모듈 로딩과 관련이 있습니다. Vite는 ESM(ECMAScript Modules)를 기본으로 사용하기 때문에, Node.js의 require와 같은 CommonJS 모듈 방식을 사용할 수 없습니다.
이 문제를 해결하기 위한 몇 가지 방법을 안내드립니다:
패키지 모듈 방식 확인:
- 우선 사용하는 모든 패키지가 ES 모듈을 지원하는지 확인해야 합니다. 만약 CommonJS 모듈을 사용 중이라면, ES Module로 대체할 수 있는지 검토해 보세요.
- 우선 사용하는 모든 패키지가 ES 모듈을 지원하는지 확인해야 합니다. 만약 CommonJS 모듈을 사용 중이라면, ES Module로 대체할 수 있는지 검토해 보세요.
Babel과 같은 트랜스파일러 사용:
- Babel을 사용하여 CommonJS 모듈을 ESM으로 트랜스파일링할 수 있습니다. Babel 설정에서
@babel/plugin-transform-modules-commonjs플러그인을 추가하여 설정을 변경해 보세요.
- Babel을 사용하여 CommonJS 모듈을 ESM으로 트랜스파일링할 수 있습니다. Babel 설정에서
Dynamic Import 사용:
- require 대신
import()를 사용하여 동적으로 모듈을 가져오는 방법으로 변환할 수 있습니다. Vite는 ESM을 지원하므로 동적 import를 문제없이 사용할 수 있습니다.
- require 대신
예시:
if (someCondition) {
import('./module.js').then(module => {
// Use the module
});
}
- Vite 설정에서 CommonJS 지원 활성화:
- Vite 설정 파일(
vite.config.js)에서optimizeDeps.include옵션을 사용하여 CommonJS 모듈을 사전 번들링할 수 있습니다.
export default { optimizeDeps: { include: ['moduleName'] } } - Vite 설정 파일(
이와 관련하여 비슷한 다른 질문들에서 해결책을 확인하실 수도 있습니다:
혹시 위의 내용으로 해결되지 않거나 추가적인 도움이 필요하신 경우, 정확한 오류 메시지나 상황을 공유해 주시면 더 자세한 도움을 드리겠습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





require문을 사용하고 싶은 것이 아닙니다.. 어디서도 require를 사용하고 있지 않은데, 정의되지 않았다는 오류가 빌드했을 때만 나타나서 한 질문입니다. (+흰화면, 빈페이지)