一般咱们使用npm init命令来建立一个npm程序时,会自动生成一个package.json
文件。package.json
文件会描述这个NPM包的全部相关信息,包括做者、简介、包依赖、构建等信息,格式是严格的JSON格式。html
经常使用命令node
npm i --save packageName 安装依赖包react
npm i --save-dev packageNamelinux
npm i webpack@1.2.1 安装指定版本的包,版本号用@符号链接webpack
属性介绍git
namees6
name
和version
是package.json中最重要的两个字段,也是发布到NPM平台上的惟一标识,若是没有正确设置这两个字段,包就不能发布和被下载。github
versionweb
包的版本号。如"1.0.0"。chrome
description
包的描述信息,将会在npm search
的返回结果中显示,以帮助用户选择合适的包。
keywords
包的关键词信息,是一个字符串数组,同上也将显示在npm search
的结果中。
homepage
包的主页地址。
bugs
包的bug跟踪主页地址。
license
包的开源协议名称。
author
包的做者。
contributors, maintainers
包的贡献者,是一个数组。
files(较少用)
包所包含的全部文件,能够取值为文件夹。一般咱们仍是用.npmignore
来去除不想包含到包里的文件。
main
包的入口文件。
bin(较少用)
若是你的包里包含可执行文件,经过设置这个字段能够将它们包含到系统的PATH
中,这样直接就能够运行,很方便。
man(较少用)
为系统的man
命令提供帮助文档。帮助文件的文件名必须以数字
结尾,若是是压缩的,须要以.gz
结尾。
"man": ["./man/foo.1", "./man/bar.1", "./man/foo.2" ]
directories(较少用)
CommonJS包所要求的目录结构信息,展现项目的目录结构信息。字段能够是:lib, bin, man, doc, example。值都是字符串。
repository
包的仓库地址。
"repository": { "type": "git", "url": "git+https://github.com/rainnaZR/es6-react.git" },
scripts
经过设置这个可使NPM调用一些命令脚本,封装一些功能。
"scripts": {"start": "babel-node src/pages/index.js", "build": "webpack --config config/webpack.config.js", "watch": "webpack-dev-server --config config/webpack.config.js --hot --inline --progress" }
config
添加一些设置,能够供scripts
读取用,同时这里的值也会被添加到系统的环境变量中。
"config": { "port": "8080" }
npm start
的时候会读取到npm_package_config_port
环境变量。
dependencies
指定依赖的其它包,这些依赖是指包发布后正常执行时所须要的,也就是线上须要的包。使用下面的命令来安装:
npm install --save packageName
若是是开发中依赖的包,能够在devDependencies
设置。
devDependencies
这些依赖只有在开发时候才须要。使用下面的命令来安装:
npm install --save-dev packageName
peerDependencies
相关的依赖,若是你的包是插件,而用户在使用你的包时候,一般也会须要这些依赖(插件),那么能够将依赖列到这里。
如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" }
bundledDependencies
绑定的依赖包,发布的时候这些绑定包也会被一同发布。
optionalDependencies(较少用)
即便这些依赖没有,也能够正常安装使用。
engines(较少用)
指定包运行的环境。
"engines": { "node": ">=0.10.3 < 0.12", "npm": "~1.0.20" }
os(较少用)
指定你的包能够在哪些系统平台下运行。
"os": [ "darwin", "linux", "!win32" ]
cpu(较少用)
能够指定包运行的cpu架构。
private
设为true
这个包将不会发布到NPM平台下。
publishConfig(较少用)
这个字段用于设置发布时候的一些设定。尤为方便你但愿发布前设定指定的tag
或registry
。
以下:
{ "name": "react", "version": "1.0.0", "description": "Command line instructions", "keywords": [ "react", "es6", "react with es6" ], "homepage": "https://github.com/rainnaZR/es6-react", "bugs": { "url": "https://github.com/rainnaZR/es6-react", "email": "111@163.com" }, "license": "ISC", "author": "ZRainna", "main": "src/pages/index.js", "directories": { "tests": "tests", "lib":"lib", "docs":"docs" }, "repository": { "type": "git", "url": "git+https://github.com/rainnaZR/es6-react.git" }, "scripts": {"start": "babel-node src/pages/index.js", "build": "webpack --config config/webpack.config.js", "watch": "webpack-dev-server --config config/webpack.config.js --hot --inline --progress" }, "babel": { "presets": [ "es2015-node5" ] }, "devDependencies": { "webpack": "^1.13.2", "webpack-dev-server": "^1.16.1" }, "dependencies": { "babel-loader": "^6.2.5", "babel-preset-es2015": "^6.14.0", "babel-preset-react": "^6.11.1", "react": "^15.3.2", "react-dom": "^15.3.2", "react-redux": "^4.4.5", "react-router": "^2.8.1", "redux": "^3.6.0" } }
参考:https://www.ijser.cn/npm-package-json-document/