跳转到内容

Npm:修订间差异

维基百科,自由的百科全书
删除的内容 添加的内容
使用HotCat已添加Category:微软
Luisleee留言 | 贡献
top:​ 维护清理
第18行: 第18行:
| released = <!-- {{Start date|YYYY|MM|DD|df=yes/no}} -->
| released = <!-- {{Start date|YYYY|MM|DD|df=yes/no}} -->
| discontinued =
| discontinued =
| latest release version = 5.6.0
| latest release version = 6.14.4
| latest release date = {{Start date and age|2017|11|28|df=yes}}<ref>{{cite web | url = https://github.com/npm/npm/releases/tag/v5.6.0 | title = Release v5.6.0 · npm/npm | date = 2017-11-28 | publisher = GitHub}}</ref>
| latest release date = {{Start date and age|2020|3|25|df=yes}}<ref>{{cite web | url = https://github.com/npm/cli/releases/tag/v6.14.4 | title = Release 6.14.4 · npm/cli | date = 2020-3-25 | publisher = GitHub}}</ref>
| frequently updated = no
| frequently updated = no
| programming language = [[JavaScript]]
| programming language = [[JavaScript]]
第26行: 第26行:
| size =
| size =
| language =
| language =
| status =
| genre =
| genre =
| license = [[艺术许可协议]] 2.0
| license = [[艺术许可协议]] 2.0
第33行: 第32行:
}}
}}


'''npm'''(全称 Node Package Manager,即“node包管理器”)是[[Node.js]]預設的、[[JavaScript]]編寫的[[軟體套件管理系統]]。
'''npm'''(全称 Node Package Manager,即“node包管理器”)是[[Node.js]]預設的、[[JavaScript]]編寫的[[軟體套件管理系統]]。


== 历史 ==
== 历史 ==

2020年4月14日 (二) 07:48的版本

npm
開發者艾萨克·施吕特、福里斯特·诺维尔、罗伯特·科瓦尔斯基、多梅尼克·德尼科拉、蒂姆·奥克斯利、埃文·马尔等
当前版本6.14.4(2020年3月25日,​4年前​(2020-03-25[1]
源代码库 編輯維基數據鏈接
编程语言JavaScript
平台Linux
macOS
Windows
许可协议艺术许可协议 2.0
网站www.npmjs.com

npm(全称 Node Package Manager,即“node包管理器”)是Node.js預設的、用JavaScript編寫的軟體套件管理系統

历史

npm完全用JavaScript写成,最初由艾萨克·施吕特(Isaac Z. Schlueter)开发。艾萨克表示自己意识到“模块管理很糟糕”的问题,并看到了PHPPEARPerlCPAN等软件的缺点,于是编写了npm。[2]

2020年3月16 日,GitHub CEO Nat Friedman 宣布 GitHub 已签署收购 NPM(npm 背后的公司)的协议,并表示 npm 加入 GitHub 后会继续免费提供公共软件注册中心服务。

说明

npm会随着Node.js自动安装[3]。npm模块仓库提供了一个名为“registry”的查询服务,用户可通过本地的npm命令下载并安装指定模块。此外用户也可以通过npm把自己设计的模块分发到registry上面[4]

registry上面的模块通常采用CommonJS格式,而且都包含一个JSON格式的元文件[5]。截止到2016年7月,npm的registry上面已经注册了超过280,000个模块[6]

npm的模块以“先到先得”的原则注册,各模块作者不会发生混乱。然而一旦有人撤回自己发布的模块,那么不仅会使依赖那个模块的项目出现问题,还会带来安全风险[7]。例如有一個模組叫做「left-pad」,其中只有一個字串對齊的功能。但是,當作者把它從registry裡面移除之後,許多模組便無法正確構建[8]

npm的registry没有审核机制,因此会存在一些低质量、不安全甚至有害的模块[5],不过npm服务器的管理员也可以删除有害模块并阻止不怀好意的用户[9]

另外也有人为npm制作了统计功能,这样可以让开发者了解各模块的使用情况,帮助他们选择合适的模块。[10]

使用

npm可以管理本地项目的所需模块并自动维护依赖情况,也可以管理全局安装的JavaScript工具[11]

如果一个项目中存在package.json文件,那么用户可以直接使用npm install命令自动安装和维护当前项目所需的所有模块[12]。在package.json文件中,开发者可以指定每个依赖项的版本范围,这样既可以保证模块自动更新,又不会因为所需模块功能大幅变化导致项目出现问题[13]。开发者也可以选择将模块固定在某个版本之上[14]

参考文献

  1. ^ Release 6.14.4 · npm/cli. GitHub. 2020-3-25. 
  2. ^ Schlueter, Isaac Z. Forget CommonJS. It's dead. **We are server side JavaScript.**. GitHub. 25 March 2013. 
  3. ^ Dierx, Peter. A Beginner's Guide to npm — the Node Package Manager. sitepoint. 30 March 2016 [22 July 2016]. 
  4. ^ Ampersand.js. Ampersand.js - Learn. ampersandjs.com. [22 July 2016]. 
  5. ^ 5.0 5.1 Ojamaa, Andres; Duuna, Karl. Assessing the Security of Node.js Platform. IEEE Xplore. 2012 [22 July 2016]. 
  6. ^ Kennedy, Hugh; DeVay, Paul. Understanding npm. Nsight. [22 July 2016]. (原始内容存档于2016年7月8日). 
  7. ^ Yegulalp, Serdar. How one yanked JavaScript package wreaked havoc. InfoWorld. 23 March 2016 [22 July 2016]. 
  8. ^ Williams, Chris. How one developer just broke Node, Babel and thousands of projects in 11 lines of JavaScript. The Register. [17 April 2016]. 
  9. ^ npm, Inc. npm. npm. [22 October 2016]. 
  10. ^ npm-stat: download statistics for NPM packages. 
  11. ^ Ellingwood, Justin. How To Use npm to Manage Node.js Packages on a Linux Server. DigitalOcean. [22 October 2016]. 
  12. ^ npm-install. docs.npmjs. [22 October 2016]. 
  13. ^ semver. docs.npmjs. [22 October 2016]. 
  14. ^ npm-version. docs.npm. [29 October 2016]. 

外部連結

参见