이 글에서는 여러분이 알아야 할 여러 유형의 npm 종속성 패키지 관리를 주로 소개합니다. npm은 node.js의 패키지 관리자이자 명령줄 도구입니다. 필요한 친구들은 이를 자세히 소개합니다. 참고해서 아래 에디터와 함께 배워보세요.
npm은 현재 다음 유형의 종속성 패키지 관리를 지원합니다.
bundledDependency / BundleDependency
를 사용하려는 경우 종속성 관리 중 하나를 선택하면 package.json의 해당 종속성 개체에 이를 넣을 수 있습니다. 예를 들어:
"devDependencies": { "fw2": "^0.3.2", "grunt": "^1.0.1", "webpack": "^3.6.0" }, "dependencies": { "gulp": "^3.9.1", "hello-else": "^1.0.0" }, "peerDependencies": { }, "optionalDependencies": { }, "bundledDependencies": []
종속성
npm install packageName --save
{ "dependencies" :{ "foo" : "1.0.0 - 2.9999.9999", // 指定版本范围 "bar" : ">=1.0.2 <2.1.2", "baz" : ">1.0.2 <=2.3.4", "boo" : "2.0.1", // 指定版本 "qux" : "<1.0.0 || >=2.3.1 <2.4.5 || >=2.5.2 <3.0.0", "asd" : "http://asdf.com/asdf.tar.gz", // 指定包地址 "til" : "~1.2", // 最近可用版本 "elf" : "~1.2.3", "elf" : "^1.2.3", // 兼容版本 "two" : "2.x", // 2.1、2.2、...、2.9皆可用 "thr" : "*", // 任意版本 "thr2": "", // 任意版本 "lat" : "latest", // 当前最新 "dyl" : "file:../dyl", // 本地地址 "xyz" : "git+ssh://git@github.com:npm/npm.git#v1.0.27", // git 地址 "fir" : "git+ssh://git@github.com:npm/npm#semver:^5.0", "wdy" : "git+https://isaacs@github.com/npm/npm.git", "xxy" : "git://github.com/npm/npm.git#v1.0.27", } }
npm install packageName --save-dev
예:
{ "name": "ethopia-waza", "description": "a delightfully fruity coffee varietal", "version": "1.2.3", "devDependencies": { "coffee-script": "~1.6.3" }, "scripts": { "prepare": "coffee -o lib/ -c src/waza.coffee" }, "main": "lib/waza.js" }
이 시점에서 --save와 --save-dev의 차이점을 이해하셨나요?
peerDependency{ "name": "gulp-my-plugin", "version": "0.0.1", "peerDependencies": { "gulp": "3.x" } }
npm ERR! peerinvalid The package gulp does not satisfy its siblings' peerDependencies requirements! npm ERR! peerinvalid Peer gulp-cli-config@0.1.3 wants gulp@~3.1.9 npm ERR! peerinvalid Peer gulp-cli-users@0.1.4 wants gulp@~2.3.0
npm install gulp-my-plugin --save-dev 명령을 실행하여 플러그인을 설치하세요. 종속성 맵을 살펴보겠습니다.
├── gulp-my-plugin@0.0.1 └── gulp@3.9.1
선택적 종속성
선택적 종속성. 설치에 실패하더라도 프로젝트가 계속 실행될 수 있는 종속 패키지가 있거나 npm을 계속 실행하려는 경우 optionDependency를 사용할 수 있습니다. 또한, optionDependency는 종속성에서 동일한 이름으로 종속성 패키지를 덮어쓰므로 두 위치 모두에 쓰지 마십시오.
예를 들어 선택적 종속성 패키지는 프로그램의 플러그인과 같습니다. 존재하면 기존 로직이 실행되고, 존재하지 않으면 다른 로직이 실행됩니다.
try { var foo = require('foo') var fooVersion = require('foo/package.json').version } catch (er) { foo = null } if ( notGoodFooVersion(fooVersion) ) { foo = null } // .. then later in your program .. if (foo) { foo.doFooThings() }
패키징 종속성인 BundledDependency는 게시 시 종속 패키지 이름을 포함하는 배열 개체입니다. 이 개체의 패키지는 최종 릴리스 패키지로 패키징됩니다. 예:
{ "name": "fe-weekly", "description": "ELSE 周刊", "version": "1.0.0", "main": "index.js", "devDependencies": { "fw2": "^0.3.2", "grunt": "^1.0.1", "webpack": "^3.6.0" }, "dependencies": { "gulp": "^3.9.1", "hello-else": "^1.0.0" }, "bundledDependencies": [ "fw2", "hello-else" ] }
패키징 명령 npm pack을 실행하면 생성된 fe-weekly-1.0.0.tgz 패키지에 fw2 및 hello-else가 포함됩니다. 그러나 이 두 패키지는 devDependency 또는 종속성에서 먼저 선언되어야 하며, 그렇지 않으면 패키징에서 오류를 보고한다는 점은 주목할 가치가 있습니다.
관련 권장 사항:
Spring Boot는 종속 패키지 Druid
node.js의 npm 및 webpack 구성 방법에 대한 자세한 설명
최신 버전의 nodejs를 사용하여 npm을 설치하는 방법
.위 내용은 여러 npm 종속성 패키지 관리 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!