inflearn logo
강의

Course

Instructor

Learn React and Firebase by following along - Creating a Chat Application [Renewed in December 2023]

Deploying your application

배포 후 빈페이지

149

SC

1 asked

0

배포했는데 화면에 아무것도 안 뜨고

콘솔창에 아래와 같은 오류가 뜹니다.

ReferenceError: require is not defined

 

검색해보니 vite가 require를 지원하지 않아서 라는데,

해결방법이 있을까요?

 

(+)

구글링 했더니 package.json에 아래 코드를 추가하면 된다는데, 이 방법도 아닌 것 같아요.

"type": "commonjs",

react 웹앱 firebase

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. SC님.

Vite 애플리케이션을 배포한 후에 “ReferenceError: require is not defined” 오류가 발생하는 문제는 CommonJS 방식의 모듈 로딩과 관련이 있습니다. Vite는 ESM(ECMAScript Modules)를 기본으로 사용하기 때문에, Node.js의 require와 같은 CommonJS 모듈 방식을 사용할 수 없습니다.

이 문제를 해결하기 위한 몇 가지 방법을 안내드립니다:

  1. 패키지 모듈 방식 확인:

    • 우선 사용하는 모든 패키지가 ES 모듈을 지원하는지 확인해야 합니다. 만약 CommonJS 모듈을 사용 중이라면, ES Module로 대체할 수 있는지 검토해 보세요.
  2. Babel과 같은 트랜스파일러 사용:

    • Babel을 사용하여 CommonJS 모듈을 ESM으로 트랜스파일링할 수 있습니다. Babel 설정에서 @babel/plugin-transform-modules-commonjs 플러그인을 추가하여 설정을 변경해 보세요.
  3. Dynamic Import 사용:

    • require 대신 import()를 사용하여 동적으로 모듈을 가져오는 방법으로 변환할 수 있습니다. Vite는 ESM을 지원하므로 동적 import를 문제없이 사용할 수 있습니다.

예시:

   if (someCondition) {
      import('./module.js').then(module => {
         // Use the module
      });
   }
  1. Vite 설정에서 CommonJS 지원 활성화:
    • Vite 설정 파일(vite.config.js)에서 optimizeDeps.include 옵션을 사용하여 CommonJS 모듈을 사전 번들링할 수 있습니다.
    export default {
      optimizeDeps: {
         include: ['moduleName']
      }
    }
    

이와 관련하여 비슷한 다른 질문들에서 해결책을 확인하실 수도 있습니다:

혹시 위의 내용으로 해결되지 않거나 추가적인 도움이 필요하신 경우, 정확한 오류 메시지나 상황을 공유해 주시면 더 자세한 도움을 드리겠습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

0

SC

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

ESlint

0

134

1

현 강의자료는 이해는 했는데, 그럼 전 강의자료는 이젠 활용을 못하나요?

0

98

0

notification 관련 질문에 AI가 엉뚱하게 대답하여 다시 질문합니다.

0

140

1

notification 관련 부분은 예전 강의를 들어야 하나요?

0

142

1

npm run build시 오류가 있습니다.

0

224

1

이미지 업로드시 403에러가 발생하는데 해결법이 있을까요?

0

777

1

이건 어디에 저장이 되는 것인가요?? redux에 저장이 되는 것인가요??

0

256

1

eslint 질문 있습니다.

0

234

1

npm create react app

0

314

2

[리덕스 미들웨어]강의 중에 createStore에서 막혔습니다.

0

528

3

회원가입 유효성 부분 페이지 안뜨는 이유 좀요....

0

284

1

강의 pdf 파일

0

435

2

파이어베이스 파일 삭제, 사진 업로드 기능 오류

0

330

1

firebase 초기화 오류

0

596

1

mime-types 패키지를 import 할 때 에러 발생

0

280

1

리덕스 스토어에 로그인 유저 정보가 저장이 되지 않는 문제

0

340

1

강의 리뉴얼 일정을 알 수 있을까요?

0

370

1

완성본으로 제공된 코드를 구동시켜보려면

2

408

1

DB와 강의 리뉴얼

0

505

1

next.js 환경에서 이 수업을 들을 수 있나요?

0

391

1

Cannot read properties of undefined (reading 'isLoading') 오류 해결법 혹시 알 수 있을까요...

0

511

1

addChatRoom 함수 작성시

0

279

1

강의 도표 자료 다운을 받으면, zip파일에 아무것도 들어있지않다고 나옵니다.

0

247

1

Favorite.js 질문입니다.! 화면 새로고침하면, 추가한 Favorite chatrooms가 날라가고 딱 1개만 남습니다!

0

298

1