인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

bestoon님의 프로필 이미지

작성한 질문수

한 입 크기로 잘라 먹는 리액트(React.js) : 기초부터 실전까지

3.5) Node.js 라이브러리 사용하기

아직은 리액트가 아닐 텐데 그럼 CJS로는 라이브러리를 사용하지 못하나요?

해결된 질문

작성

·

54

0

이전 강의에서 package.json에 "type": "module"을 추가한 상태이고 라이브러리를 가져올 때 사용한 문법이 ESM인 것 같은데 CJS로도 가능한지 궁금합니다.

답변 2

0

이정환 Winterlood님의 프로필 이미지
이정환 Winterlood
지식공유자

안녕하세요 이정환입니다.

package.json에 type: "module" 옵션을 추가해 주셨다면 이제부터 작성하시는 코드는 모두 ESM 방식으로 작성하셔야 합니다. 따라서 CJS 방식으로 외부 라이브러리를 불러오는 코드는 작성하실 수 없게 됩니다.

 

0

인프런 AI 인턴님의 프로필 이미지

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

ES 모듈(ESM)을 사용하고 계신다면, CommonJS(CJS) 모듈 시스템과 약간의 차이가 있습니다. ESM은 주로 importexport 구문을 사용하여 모듈을 처리하는 반면, CJS는 requiremodule.exports를 사용합니다.

ES 모듈과 CommonJS

  • ESM(ES 모듈): import { something } from 'module'; 이러한 문법을 사용합니다. Node.js에서도 package.json"type": "module"을 명시하면 해당 문법을 사용할 수 있습니다.
  • CJS (CommonJS): const something = require('module'); 방식으로 모듈을 가져오는 방식입니다. 기본적으로 Node.js에서 지원하는 방식이기도 합니다.

ESM에서 CJS 모듈 사용하기

현재 ESM을 사용하고 있다면, 기본적으로 require를 사용할 수 없습니다. 두 모듈 시스템을 함께 사용할 경우 약간의 조정이 필요할 수 있습니다. 가장 직접적인 방법은 CJS 모듈을 ESM에서 import로 사용하는 것입니다. 예를 들어, 다음과 같은 방법을 활용할 수 있습니다:

import module from 'module';

Node.js의 최신 버전에서는 esm 패키지를 통해 CJS 모듈도 ESM 환경에서 사용 가능하도록 설정할 수 있습니다. 이렇듯 일부 라이브러리나 모듈은 CJS 형식으로만 제공되기 때문에 이 경우 설정이 필요할 수 있습니다.

추가 참고 자료

이전에 package.json"type": "module"을 추가함으로써 ESM 환경을 설정하셨으니, 꼭 이 부분을 고려하여 작성하셔야 합니다. CJS로 작성된 대부분의 패키지는 아직도 호환성이 유지되고 있으므로, 사용하시는 라이브러리의 공식 문서를 참고해 보시는 것도 좋은 방법입니다.

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

bestoon님의 프로필 이미지

작성한 질문수

질문하기