溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

package.json各個(gè)屬性的示例分析

發(fā)布時(shí)間:2021-06-08 11:42:15 來(lái)源:億速云 閱讀:210 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)package.json各個(gè)屬性的示例分析,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

什么是Node.js的模塊(Module)?
在Node.js中,模塊是一個(gè)庫(kù)或框架,也是一個(gè)Node.js項(xiàng)目。Node.js項(xiàng)目遵循模塊化的架構(gòu),當(dāng)我們創(chuàng)建了一個(gè)Node.js項(xiàng)目,意味著創(chuàng)建了一個(gè)模塊,這個(gè)模塊的描述文件,被稱為package.json ——  【長(zhǎng)城_changcheng】

一般package.json放置在項(xiàng)目根目錄下,其基本結(jié)構(gòu)如下圖所示:

package.json各個(gè)屬性的示例分析

package.json 結(jié)構(gòu)圖

屬性介紹

description

字符串。用來(lái)描述當(dāng)前項(xiàng)目的大致功能。

name

此項(xiàng)目包的名稱。在不確定自己的包名能否使用之前,請(qǐng)先npm registry 一下,看看當(dāng)前你喜歡的包名是否已經(jīng)被占用。

version

當(dāng)前項(xiàng)目包的版本號(hào)。每一次項(xiàng)目改動(dòng)時(shí),在即將發(fā)布時(shí),都要同步的去更改項(xiàng)目的版本號(hào)。一般格式為:x.y.z。意思是:大版本.中版本.小版本

keywords

放簡(jiǎn)介,字符串。方便屌絲們?cè)?npm search中搜索

homepage

項(xiàng)目官網(wǎng)的url

bugs

你項(xiàng)目的提交問(wèn)題的url和(或)郵件地址。這對(duì)遇到問(wèn)題的屌絲很有幫助。

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

你可以指定一個(gè)或者指定兩個(gè)。如果你只想提供一個(gè)url,那就不用對(duì)象了,字符串就行。如果提供了url,它會(huì)被npm bugs命令使用。

license

你應(yīng)該要指定一個(gè)許可證,讓人知道使用的權(quán)利和限制的。最簡(jiǎn)單的方法是,假如你用一個(gè)像BSD或者M(jìn)IT這樣通用的許可證,就只需要指定一個(gè)許可證的名字,像這樣:

{ "license" : "BSD" }

author

項(xiàng)目作者??梢灾付╪ame,email,url字段信息。也可以單獨(dú)使用字符串來(lái)表示。

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

contributors

項(xiàng)目相關(guān)貢獻(xiàn)者。是數(shù)組。用于羅列對(duì)應(yīng)的貢獻(xiàn)人??梢允菃为?dú)的字符串,也可以分別指定name,email,url等屬性。

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

files

files是一個(gè)包含項(xiàng)目中的文件的數(shù)組。如果命名了一個(gè)文件夾,那也會(huì)包含文件夾中的文件。(除非被其他條件忽略了)你也可以提供一個(gè).npmignore文件,讓即使被包含在files字段中得文件被留下。其實(shí)就像.gitignore一樣。

{ "files": [ "bin/", "templates/", "test/" ]}

main

main字段是一個(gè)模塊ID,它是一個(gè)指向你程序的主要項(xiàng)目。就是說(shuō),如果你包的名字叫foo,然后用戶安裝它,然后require("foo"),然后你的main模塊的exports對(duì)象會(huì)被返回。這應(yīng)該是一個(gè)相對(duì)于根目錄的模塊ID。對(duì)于大多數(shù)模塊,它是非常有意義的,其他的都沒(méi)啥。

{ "main": "bin/index.js"}

bin

很多包都有一個(gè)或多個(gè)可執(zhí)行的文件希望被放到PATH中。(實(shí)際上,就是這個(gè)功能讓npm可執(zhí)行的)。要用這個(gè)功能,給package.json中的bin字段一個(gè)命令名到文件位置的map。初始化的時(shí)候npm會(huì)將他鏈接到prefix/bin(全局初始化)或者./node_modules/.bin/(本地初始化)。

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

當(dāng)你初始化npm,它會(huì)創(chuàng)建一個(gè)符號(hào)鏈接到cli.js腳本到/usr/local/bin/npm。如果你只有一個(gè)可執(zhí)行文件,并且名字和包名一樣。那么你可以只用一個(gè)字符串,比如

{ "name": "my-program" , "version": "1.2.5" , "bin": "./path/to/program" }

// 等價(jià)于

{ "name": "my-program" , "version": "1.2.5" , "bin" : { "my-program" : "./path/to/program" } }

man

指定一個(gè)單一的文件或者一個(gè)文件數(shù)組供man程序使用。如果只提供一個(gè)單一的文件,那么它初始化后就是man 的結(jié)果,而不管實(shí)際的文件名是神馬,比如:

{ "name" : "foo" , "version" : "1.2.3" , "description" : "A packaged foo fooer for fooing foos" , "main" : "foo.js" , "man" : "./man/doc.1" }

這樣man foo就可以用到./man/doc.1文件了。

如果文件名不是以包名開頭,那么它會(huì)被冠以前綴,下面的:

{ "name" : "foo" , "version" : "1.2.3" , "description" : "A packaged foo fooer for fooing foos" , "main" : "foo.js" , "man" : [ "./man/foo.1", "./man/bar.1" ] }

會(huì)為man foo和man foo-bar創(chuàng)建文件。

man文件需要以數(shù)字結(jié)束,然后可選地壓縮后以.gz為后綴。

{ "name" : "foo" , "version" : "1.2.3" , "description" : "A packaged foo fooer for fooing foos" , "main" : "foo.js" , "man" : [ "./man/foo.1", "./man/foo.2" ] }

會(huì)為man foo和man 2 foo創(chuàng)建。

repository

指定你的代碼存放的地方。這個(gè)對(duì)希望貢獻(xiàn)的人有幫助。如果git倉(cāng)庫(kù)在github上,那么npm docs命令能找到你。

scripts

“scripts”是一個(gè)由腳本命令組成的hash對(duì)象,他們?cè)诎煌纳芷谥斜粓?zhí)行。key是生命周期事件,value是要運(yùn)行的命令。

config

"config" hash可以用來(lái)配置用于包腳本中的跨版本參數(shù)。在實(shí)例中,如果一個(gè)包有下面的配置

{ "name" : "foo" , "config" : { "port" : "8080" } }

然后有一個(gè)“start”命令引用了npm_package_config_port環(huán)境變量,用戶可以通過(guò)npm config set foo:port 8001來(lái)重寫他。

dependencies

依賴是給一組包名指定版本范圍的一個(gè)hash。這個(gè)版本范圍是一個(gè)由一個(gè)或多個(gè)空格分隔的字符串。依賴還可以用tarball或者git URL。

請(qǐng)不要將測(cè)試或過(guò)渡性的依賴放在dependencies。

對(duì)于引用包的版本號(hào)格式,以下都是合法的:

{ "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"   , "two" : "2.x"   , "thr" : "3.3.x"  ,"vue":"*", "element-ui":"" } }

devDependencies

如果有人要用你的模塊,但他們可能不需要你開發(fā)所使用的外部測(cè)試或者文檔框架。在這種情況下,最好將這些附屬的項(xiàng)目列在devDependencies中。這些東西會(huì)在根目錄執(zhí)行npm link或者npm install的時(shí)候初始化,并可以像其他npm配置參數(shù)一樣管理。

peerDependencies

你的模塊可能要暴露一個(gè)特定的接口,并由host文檔來(lái)預(yù)期和指定。比如:

{   "name": "tea-latte",   "version": "1.3.5"   "peerDependencies": {     "tea": "2.x"   } }

這能保證你的package可以只和tea的2.x版本一起初始化。試圖初始化另一個(gè)有會(huì)沖突的依賴的插件將導(dǎo)致一個(gè)錯(cuò)誤。因此,確保你的插件的需求約束越弱越好,而不要去把它鎖定到一個(gè)特定的版本。此屬性盡量避免使用

bundledDependencies

一組包名,他們會(huì)在發(fā)布的時(shí)候被打包進(jìn)去

engines

指定項(xiàng)目工作的環(huán)境。除非用戶設(shè)置engine-strict標(biāo)記,這個(gè)字段只是建議值。

{ "engines" : { "node" : ">=0.10.3 <0.12", "npm" : "~1.0.20" } }

engineStrict

如果你確定你的模塊一定不會(huì)運(yùn)行在你指定版本之外的node或者npm上,你可以在package.json文件中設(shè)置"engineStrict":true。它會(huì)重寫用戶的engine-strict設(shè)置。除非你非常非常確定,否則不要這樣做。如果你的engines hash過(guò)度地限制,很可能輕易讓自己陷入窘境。慎重地考慮這個(gè)選擇。如果大家濫用它,它會(huì)再以后的npm版本中被刪除。

os

可以指定你的模塊要運(yùn)行在哪些操作系統(tǒng)中

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

你也可以用黑名單代替白名單,在名字前面加上“!”就可以了:

"os" : [ "!win32" ]

操作系統(tǒng)用process.platform來(lái)探測(cè)。雖然沒(méi)有很好地理由,但它是同時(shí)支持黑名單和白名單的。

cpu

如果你的代碼只能運(yùn)行在特定的cpu架構(gòu)下,你可以指定一個(gè)

"cpu" : [ "x64", "ia32" ]

就像os選項(xiàng),你也可以黑一個(gè)架構(gòu):

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

cpu架構(gòu)用process.arch探測(cè)。

preferGlobal

如果包主要是需要全局安裝的命令行程序,就設(shè)置它為true來(lái)提供一個(gè)warning給只在局部安裝的人。它不會(huì)真正的防止用戶在局部安裝,但如果它沒(méi)有按預(yù)期工作它會(huì)幫助防止產(chǎn)生誤會(huì)。

{" preferGlobal ":true}

private

如果你設(shè)置"private": true,npm就不會(huì)發(fā)布它。

這是一個(gè)防止意外發(fā)布私有庫(kù)的方式。如果你要確定給定的包是只發(fā)布在特定registry(如內(nèi)部registry)的,用publishConfighash的描述來(lái)重寫registry的publish-time配置參數(shù)。

publishConfig

這是一個(gè)在publish-time使用的配置集合。當(dāng)你想設(shè)置tag或者registry的時(shí)候它非常有用,所以你可以確定一個(gè)給定的包沒(méi)有打上“l(fā)astest”的tag或者被默認(rèn)發(fā)布到全局的公開registry。任何配置都可以被重寫,但當(dāng)然可能只有“tag”和“registry”與發(fā)布的意圖有關(guān)。

關(guān)于“package.json各個(gè)屬性的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI