CommonJS 와 AMD
JavaScript 의 모듈화
CommonJS
- JavaScript 를 브라우저에서뿐 아니라, Server Side, Desktop Application 에서도 사용하려고 조직한 자발적 워킹 그룹입니다. 
- 2005년 Ajax 가 부상하면서 더 빠른 JavaScript 엔진이 필요하게 되었고, 2008년 Google 의 V8 JavaScript 엔진이 공개되면서 브라우저 밖에서도 충분히 쓸만한 성능이 보장되었습니다. 
- 2009년 Kevin Dangoor 가 Server Side JavaScript 아이디어를 제시했고, 공동 표준을 정하고 지켜나가는 활동이 필요하다 보았고, 3개월 후 CommonJS API 0.1 을 출시했습니다. 
Server Side JavaScript
- 서로 호환되는 표준 라이브러리가 없다. 
- 데이터베이스에 연결할 수 있는 표준 인터페이스가 없다. 
- 다른 모듈을 삽입하는 표준적인 방법이 없다. 
- 코드를 패키징해서 배포하고 설치하는 방법이 필요하다. 
- 의존성 문제까지 해결하는 공통 패키지 모듈 저장소가 필요하다. 
위에 제기된 문제점들을 해결할 방법은 '모듈화' 입니다.
모듈화
- 브라우저용 언어를 넘어 범용적으로 JavaScript 를 사용하기 위 선결조건 '모듈화' 
모듈화 구성 요소 
- 스코프(Scope): 모든 모듈은 자신만의 독립적인 실행 영역이 있어야 한다. 
- 정의(Definition): 모듈 정의는 exports 객체를 이용한다. 
- 사용(Usage): 모듈 사용은 require 함수를 이용한다. 
모듈은 자신만의 독립적인 실행 영역이 필요하고, 파일마다 독립적인 파일 스코프가 있기 때문에, 보통 파일 하나에 모듈 하나를 작성합니다.
모듈화의 문제점
- 필요한 모듈을 모두 내려받을 때까지 아무것도 할 수 없게 됩니다. 
- 이 단점을 극복하려는 여러 방법이 CommonJS에서 논의되었지만, 결국 동적으로 < script > 태그를 삽입하는 방법으로 가닥을 잡는다. 
- < script > 태그를 동적으로 삽입하는 방법은 JavaScript 로더들이 사용하는 가장 일반적인 방법이기도 하다. 
서버 모듈을 비동기적으로 클라이언트에게 전송하기
- 표준 < script > 태그를 이용해 앞에서 예로 든 fileA와 fileB를 차례대로 로드하면, fileB의 변수가 fileA의 변수를 모두 덮어쓰게 되는 전역변수 문제도 발생한다. 
- 이런 문제를 해결하려고 CommonJS는 서버 모듈을 비동기적으로 클라이언트에 전송할 수 있는 모듈 전송 포맷(module transport format)을 추가로 정의했다. 
- 이 명세에 따라 서버사이드에서 사용하는 모듈을 다음 예의 브라우저에서 사용하는 모듈과 같이 전송 포맷으로 감싸면 서버 모듈을 비동기적으로 로드할 수 있게 된다. 
AMD
- JavaScript 표준 API 라이브러리 제작 그룹에는 CommonJS만 있는 것이 아니고, AMD(Asynchronous Module Definition)라는 그룹도 있다. 
- AMD 그룹은 비동기 상황에서도 JavaScript 모듈을 쓰기 위해 CommonJS에서 함께 논의하다 합의점을 이루지 못하고 독립한 그룹이다. 
Last updated
Was this helpful?