Node.js 언어에서는 패키지와 모듈 사이에 본질적인 차이가 없습니다. 패키지는 모듈을 기반으로 한 더 깊은 추상화입니다. 패키지는 독립적인 기능을 캡슐화하고 게시, 업데이트, 종속성 관리 및 버전 제어 수행에 사용됩니다. Node.js는 CommonJS 사양에 따라 패키지 메커니즘을 구현하며, 패키지 게시 및 획득 요구 사항을 해결하기 위해 npm이 개발되었습니다.
Node.js의 패키지는 JSON 형식의 패키지 설명 파일 package.json이 포함된 디렉터리입니다. Node.js의 패키지는 기본적으로 CommonJS 스펙을 따르므로 다음과 같은 특징을 가지고 있습니다.
CommonJS 사양에 정의된 패키지 기능:
1) 최상위 디렉터리에는 package.json 파일이 포함되어 있습니다.
2) bin 디렉토리는 바이너리 파일을 저장합니다.
3) lib 디렉토리는 JavaScript 파일을 저장합니다.
4) 문서 디렉토리는 문서를 저장합니다.
5) 테스트 디렉터리에는 단위 테스트가 저장됩니다.
Node.js 모듈과 파일은 일대일 대응을 갖습니다. 파일은 JavaScript 소스 파일이나 바이너리 파일일 뿐만 아니라 디렉터리일 수도 있습니다. 가장 간단한 패키지는 디렉토리 모듈입니다.
Node.js 패키지는 일반적으로 모듈을 기반으로 더 높은 수준의 추상화를 제공하는 모듈 모음으로, 일부 고정 인터페이스를 제공하는 함수 라이브러리와 동일합니다.
package.json을 사용자 정의하면 릴리스용 패키지를 더욱 복잡하고 완전하며 규정을 준수하는 패키지로 만들 수 있습니다.
Node.js는 패키지를 호출할 때 먼저 패키지에 있는 package.json 파일의 메인 필드를 확인하고, package.json 파일의 메인 필드가 그렇지 않은 경우 이를 패키지의 인터페이스 모듈로 사용합니다. 존재하는 경우 Node.js는 패키지의 인터페이스로 index.js 또는 index.node를 찾으려고 시도합니다.
package.json 파일은 CommonJS 사양에서 패키지를 설명하는 데 사용되는 파일입니다. 사양을 완전히 준수하는 package.json 파일에는 다음 필드가 포함되어야 합니다.
1) 이름: 패키지 이름. 패키지 이름은 고유하며 소문자, 숫자, 밑줄로 구성되며 공백을 포함할 수 없습니다.
2) 설명: 패키지 설명입니다. 패키지에 대해 간략하게 설명해주세요.
3) 버전: 버전 번호. "의미적 버전 식별" 사양을 충족하는 버전 문자열입니다.
4) 키워드: 일반적으로 검색에 사용되는 키워드 배열입니다.
5) 유지관리자: 유지관리자의 배열입니다. 각 요소에는 이름, 이메일(선택 사항), 웹(선택 사항) 필드가 포함됩니다.
6) 기여자: 기여자의 배열입니다. 형식은 관리자 배열과 동일합니다. 패키지 작성자는 contributors 배열의 첫 번째 요소여야 합니다.
7) 버그: 버그를 제출할 주소로 웹사이트나 이메일 주소를 사용할 수 있습니다.
8) 라이센스: 라이센스 배열. 각 요소에는 유형(라이센스 이름) 및 URL(라이센스 텍스트에 대한 주소 링크) 필드가 포함되어야 합니다.
9) 저장소: 창고 호스팅 주소의 배열입니다. 각 요소에는 유형(Git과 같은 웨어하우스 유형), url(웨어하우스 주소) 및 경로(웨어하우스 관련 경로, 선택 사항) 필드가 포함되어야 합니다.
10) 종속성: 패키지 종속성. 패키지 이름과 버전 번호로 구성된 연관 배열입니다.
참고: "의미적 버전 식별" 사양은 해외에서 제안된 일련의 버전 명명 사양입니다. 원래 목적은 다양한 버전 번호 크기 비교 문제를 해결하는 것이었습니다. 현재 많은 패키지 관리 시스템에서 채택되고 있습니다.
다음은 CommonJS 사양을 완벽하게 준수하는 package.json 예시입니다.