package.json
文件描述了一个NPM包的所有相关信息,包括作者、简介、包依赖、构建等信息。格式必须是严格的JSON格式。
通常我们在创建一个NPM程序时,可以使用npm init
命令,通过交互式的命令,自动生成一个package.json
文件,里面包含了常用的一些字段信息,但远不止这么简单。通过完善package.json
文件,我们可以让npm
命令更好地为我们服务。
name
和version
是package.json中最重要的两个字段,也是发布到NPM平台上的唯一标识,如果没有正确设置这两个字段,包就不能发布和被下载。
下面是官方给出的一些建议:
engines
字段来指定。.
和_
开头。require()
命令的参数,所以应该尽量简明。@ijse/mypackage
。
npm search
的返回结果中显示,以帮助用户选择合适的包。
npm search
的结果中。
bugs: {
"url": "http://github.com/ijse/project/issues",
"i@ijser.cn": "my@ijser.cn"
}
author: {
"name": "ijse",
"i@ijser.cn": "my@ijse.cn",
"url": "http://www.ijser.cn"
}
或者:
author: "ijse <my@ijser.cn> (http://www.ijser.cn)"
通常我们还是用.npmignore
来去除不想包含到包里的文件。
index.js
PATH
中,这样直接就可以运行,很方便。如:
"bin": {
"iapp": "./cli.js"
}
当包被安装后,NPM将创建一个cli.js
文件的链接到/usr/local/bin/iapp
下。
man
命令提供帮助文档, 如:
"man": "./man/doc.1"
帮助文件的文件名必须以数字
结尾,如果是压缩的,需要以.gz
结尾。 如果是字符串数组:
"name": "foo",
"man": ["./man/foo.1", "./man/bar.1", "./man/foo.2" ]
则分别可以man foo
, man foo-bar
, man 2 foo
来查看。
"repository": {
"type": "git",
"url": "http://github.com/ijse/project.git"
}
scripts
读取用,同时这里的值也会被添加到系统的环境变量中。
"name": "foo",
"config": {
"port": "8080"
}
npm start
的时候会读取到npm_package_config_port
环境变量。 同时也可以使用npm config
命令来修改设置:
npm config set foo:port 8001
devDependencies
设置。 通常使用下面命令来安装:
npm install --save otherpackage
形式可以有如下多种:
version
严格匹配某个版本>version
必须大于某个版本>=version
<version
<=version
~version
大概匹配某个版本^version
兼容某个版本1.2.x
可以是1.2.0, 1.2.1等等,但不能是1.3.0http://...
指定tarball的url地址*
任何版本都可以""
同上version1 - version2
>=version1 <=version2range1 || range2
满足range1 或range2git://...
git地址user/repo
同上tag
指定某个tag的版本path/path
本地包所有文件夹{ "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 ❤️.0.0"
, "asd" : "http://asdf.com/asdf.tar.gz"
, "til" : "~1.2"
, "elf" : "~1.2.3"
, "two" : "2.x"
, "thr" : "3.3.x"
, "lat" : "latest"
, "dyl" : "file:../dyl"
}
}
Git URL可以有如下种形式:
git://github.com/user/project.git#commit-ish
git+ssh://user@hostname:project.git#commit-ish
git+ssh://user@hostname/project.git#commit-ish
git+http://user@hostname/project/blah.git#commit-ish
git+https://user@hostname/project/blah.git#commit-ish
npm install --save-dev mypack
举个例子,如karma
, 它的package.json
中有设置:
"peerDependencies": {
"karma-jasmine": "~0.1.0",
"karma-requirejs": "~0.2.0",
"karma-coffee-preprocessor": "~0.1.0",
"karma-html2js-preprocessor": "~0.1.0",
"karma-chrome-launcher": "~0.1.0",
"karma-firefox-launcher": "~0.1.0",
"karma-phantomjs-launcher": "~0.1.0",
"karma-script-launcher": "~0.1.0"
}
这些都是karma
的相关插件,一般使用karma
的时候都会需要。
"engines": {
"node": ">=0.10.3 < 0.12",
"npm": "~1.0.20"
}
true
强制限定 engine
"os": [ "darwin", "linux", "!win32" ]
即可以在darwin
和linux
平台下运行,而不能在win32
下。这里设定的取值是来自process.platform
的。
"cpu": [ "x64", "!arm" ]
取值来自process.arch
。
true
建议用户全局(npm install -g
)安装。但它并不强制用户。
true
这个包将不会发布到NPM平台下。
tag
或registry
。 也可以设定其它子字段,但只有tag
和registry
会影响到发布。
"scripts": { "start": "node server.js" }
如果在项目根目录下含有server.js
文件,则NPM会自动设置此值。"scripts": { "preinstall": "node-gyp rebuild" }
如果在项目根目录下含有binding.gyp
文件,则NPM会自动设置此值。"contributors": [...]
如果项目根目录下含有AUTHORS
文件,则NPM会自动将每一行以Name <i@ijser.cn> (url)
的格式读取并设定此字段。