貼士:package.json 字段解析

name

必須字段。提示:

  • 不要在name中包含 js、 node 字樣;
  • 這個(gè)名字最終會(huì)是 URL 的一部分,命令行的參數(shù),目錄名,所以不能以點(diǎn)號(hào)或下劃線開頭;
  • 這個(gè)名字可能在 require 方法中被調(diào)用,所以應(yīng)該盡可能短;
  • 如果要發(fā)布為一個(gè) NPM 包,則該名字必須為唯一;

version

必須字段,版本號(hào),字符串格式,如:

"version": "1.0.0"

description

可選字段,字符串格式,如:

"description": "簡(jiǎn)單描述當(dāng)前應(yīng)用或 package"

keywords

可選字段,數(shù)組格式,如:

"keywords": [“關(guān)鍵字”,“keyword”]

homepage

可選字段,項(xiàng)目主頁 URL,如:

"homepage": "https://github.com/github/github"

bugs

可選字段,問題追蹤系統(tǒng)的URL或郵箱地址;npm bugs用的上。

{
  "url" :"http://github.com/owner/project/issues",
  "email" :"project@hostname.com"
}

license

可選字段。如果是使用一個(gè)普遍的license,比如 BSD-3-ClauseMIT,直接使用:

{ "license" : "BSD-3-Clause" }

author, contributors

都是可選字段。author 作者,contributors 貢獻(xiàn)者。
author的格式如下:

{ 
  "name" : "Barney Rubble",
  "email" : "b@rubble.com",
  "url" : "http://barnyrubble.tumblr.com/"
}

這種格式也可以:

"Barney Rubble <b@rubble.com> (http://barnyrubble.tumblr.com/)"

貢獻(xiàn)者:

"contributors": [
    "?ndrew Rininsland <aendrew.rininsland@thetimes.co.uk> (http://www.aendrew.com)",
    "Aurelio De Rosa <a.derosa@audero.it> (http://www.audero.it/)",
    "Clay Reimann <clayreimann@gmail.com> (http://clayreimann.me)",
    "Michael Aufreiter (http://substance.io)",
    "Mathieu Dutour <mathieu@dutour.me> (https://github.com/mathieudutour)"
  ],

files

可選字段,項(xiàng)目包含的一組文件。如果是文件夾,文件夾下的文件也會(huì)被包含。如果需要把某些文件不包含在項(xiàng)目中,添加一個(gè) .npmignore 文件。這個(gè)文件和.gitignore類似,如:

"files": [
  "dist/*"
],

main

可選字段,建議必填。這個(gè)字段的值是你程序主入口模塊的ID。

  • 如果其他用戶需要你的包,當(dāng)用戶調(diào)用 require() 方法時(shí),返回的就是這個(gè)模塊的導(dǎo)出(exports);
  • 如果發(fā)布為一個(gè) NPM Package,則 require 為該屬性指定的文件;
  • 如果未指定該屬性,則默認(rèn)為根目錄下的 index.js 或 index.node;
    示例:
"main": "dist/components/GitHub.js",
"main": "index.js",
"main": "app.js",

scripts

可選,對(duì)象格式,如:

 "scripts":{
  "start": "node app.js",
  "server": "node server/server.js",
  "preinstall":"node-gyp rebuild"
}

可在終端使用 npm run start 來執(zhí)行指定的腳本。如果包里有 binding.gyp,npm 默認(rèn)在 preinstall 命令時(shí),使用 node-gyp 做編譯。

bin

可選字段。很多的包都會(huì)有執(zhí)行文件需要安裝到 PATH 中去。
這個(gè)字段對(duì)應(yīng)的是一個(gè)Map,每個(gè)元素對(duì)應(yīng)一個(gè){ 命令名:文件名 }。

{
  "bin" : {
    "npm": "./cli.js"
  }
}

directories

用于指示包的目錄結(jié)構(gòu):

directories.lib

指示庫文件的位置。

directories.bin

和前面的bin是一樣的,但如果前面已經(jīng)有bin,那么這個(gè)就無效。
除了以上兩個(gè),還有Directories.docDirectories.man、Directories.example

repository

可選字段。用于指示代碼存放的位置。

"repository": {
  "type": "git",
  "url": "http://github.com/npm/npm.git"
}

或使用SVN:

"repository": {
  "type": "svn",
  "url": "http://v8.googlecode.com/svn/trunk/"
}

config

可選字段,object。config 對(duì)象中的值在 Scripts 的整個(gè)周期中皆可用,專門用于給 Scripts 提供配置參數(shù)。

dependencies

可選字段,指示當(dāng)前包所依賴的其他包。

{
  "dependencies": {
    "foo": "1.0.0 - 2.9999.9999",
    "bar": ">=1.0.2 <2.1.2"
  }
}

版本格式可以是下面任一種:

  • version 完全匹配
  • >version 大于這個(gè)版本
  • >=version 大于或等于這個(gè)版本
  • <version 小于這個(gè)版本
  • <=version 小于或等于這個(gè)版本
  • ~version 非常接近這個(gè)版本
  • ^version 與當(dāng)前版本兼容
  • 1.2.x X代表任意數(shù)字,因此 1.2.1, 1.2.3 等都可以。
  • http://... Unix 系統(tǒng)下使用的 tarball 的 URL。
  • * 任何版本都可以
  • "" 任何版本都可以
  • version1 - version2 等價(jià)于 >=version1 <=version2
  • range1 || range2 滿足任意一個(gè)即可
  • git... Git地址
  • user/repo

devDependencies

可選字段,開發(fā)環(huán)境下的依賴包,格式同 dependencies 屬性。

peerDependencies

可選字段。兼容性依賴。如果你的包是插件,適合這種方式。

bundledDependencies

可選字段。發(fā)布包時(shí)同時(shí)打包的其他依賴。

optionalDependencies

可選字段。如果你想在某些依賴即使沒有找到,或則安裝失敗的情況下,npm 都繼續(xù)執(zhí)行。那么這些依賴適合放在這里。

engines

可選字段。既可以指定 node 版本:

{ "engines" : {"node" : ">=0.10.3 <0.12" } }

也可以指定npm版本:

{ "engines" : {"npm" : "~1.0.20" } }

engineStrick

可選字段,布爾值。如果你肯定你的程序只能在制定的 engine 上運(yùn)行,設(shè)置為 true。

os

可選字段。指定模塊可以在什么操作系統(tǒng)上運(yùn)行:

"os" : [ "darwin","linux" ]
"os" : [ "!win32" ]

CPU

可選字段。指定CPU型號(hào)。

"cpu" : [ "x64","ia32" ]
"cpu" : [ "!arm","!mips" ]

preferGlobal

可選字段,布爾值。如果你的包是個(gè)命令行應(yīng)用程序,需要全局安裝,就可以設(shè)為 true。

private

可選字段,布爾值。如果 private 為 true,npm 會(huì)拒絕發(fā)布。這可以防止私有 repositories 不小心被發(fā)布出去,示例:

"private": true

publishConfig

可選字段。發(fā)布時(shí)使用的配置值。

資料

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 原文鏈接:http://www.mujiang.info/translation/npmjs/files/pack...
    R_X閱讀 1,101評(píng)論 0 1
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,506評(píng)論 19 139
  • 什么是 NPM npm之于Node,就像pip之于Python,gem之于Ruby,composer之于PHP。 ...
    ihoey閱讀 6,361評(píng)論 2 36
  • linux資料總章2.1 1.0寫的不好抱歉 但是2.0已經(jīng)改了很多 但是錯(cuò)誤還是無法避免 以后資料會(huì)慢慢更新 大...
    數(shù)據(jù)革命閱讀 13,180評(píng)論 2 33
  • npm是什么 NPM的全稱是Node Package Manager,是隨同NodeJS一起安裝的包管理和分發(fā)工具...
    build1024閱讀 8,123評(píng)論 0 9

友情鏈接更多精彩內(nèi)容