初识NPM

NPM是什么?

npm是世界上最大的软件注册表, npm由3个独立的部分组成:

  • 网站:开发者查找包,设置参数以及管理npm使用体验的途径

  • 注册表(registry):是一个巨大的数据库,保存了每个包的信息

  • 命令行工具(CLI):终端,使用者通过cli操作npm

Node.js框架的最强大功能之一是能够轻松地使用Node包管理器(Node Package Manager,NPM)用额外的Node封装模块(NPM)将其扩展。 在Node.js的世界里,您可以看到NPM有几个意思:

Node包管理器(服务于JavaScript)

Node封装模块

此外,NPM还是一个网站(www.npmjs.com)和社区平台

NPM可以做什么?

  • 为你的项目引入packages

  • 下载你可以立即使用的独立的工具

  • 在任何地点和npm user 共享代码

  • 设定代码开发权限

  • 组件虚拟团队

  • 管理代码版本和依赖

  • 当底层代码更新时,轻松的更新应用程序

  • 为难题找到多种解决途径

  • 找到和你解决同一个问题的伙伴

基础命令行

npm install : 使用 npm 命令安装模块

npm view moduleNames :查看node模块的package.json文件夹

npm list :查看当前目录下已安装的node包

npm help :查看帮助命令

npm view moudleName dependencies :查看包的依赖关系

npm view moduleName repository.url :查看包的源文件地址

npm view moduleName engines :查看包所依赖的Node的版本

npm help folders :查看npm使用的所有文件夹

npm rebuild moduleName :用于更改包内容后进行重建

npm outdated :检查包是否已经过时,此命令会列出所有已经过时的包,可以及时进行包的更新

npm update moduleName :更新node模块

npm uninstall moudleName :卸载node模块

npm search packageName :发布一个npm包的时候,需要检验某个包名是否已存在

npm init :会引导你创建一个package.json文件,包括名称、版本、作者这些信息等,

npm root :查看当前包的安装路径

npm -v :查看npm安装的版本

npm config ls : 查看全局安装路径

相关操作

安装npm 并管理npm版本

npm是用node.js编写的 ,首先要在电脑里安装node 环境,去node官网下载LTS(long time support )版本。 安装之后,run node -v

npm会在安装nodejs之后自动安装,通常npm的更新比node 更加频繁,确保你时刻是最新版本。 当前版本:npm -v 升级:npm install npm@latest -g

nvm

由于npm和node.js产品由不同的实体管理,因此更新和维护可能变得复杂。 此外,Node.js安装过程将npm安装在仅具有本地权限的目录中。 当您尝试全局运行包时,这可能会导致权限错误。为了解决这两个问题,许多开发人员选择使用版本管理器或nvm来安装npm。 版本管理器将避免权限错误,并将解决更新Node.js和npm的复杂性。

如何防止权限错误

当全局安装包时发生EACCES错误: https://www.npmjs.com.cn/getting-started/fixing-npm-permissions/

如何安装本地包

  • 本地安装 (模块依赖并通过require加载,命令的默认行为)

  • 全局安装(将包作为一个命令行工具 比如gruntCLI) 选择哪种方式安装,取决于我如何使用这个包 npm install <packagename> 执行上面这句产出node_modules文件夹

使用 package.json

package.json文件:

  • 列举了项目所有依赖

  • 允许指定项目使用的包的版本

  • 使构建过程可重现,更容易与其他开发同学共享 package.json命名规则: “name”:小写字母,一个单词,不可以有空白字符,可以用破折号或下划线。 “version”:"1.2.3" 创建package.json文件: npm initnpm init --yes 区别是第一个会挨个字段询问答完一份调查问卷,--yes生成默认的文件

如何更新本地安装的包

1.在 package.json文件所在目录执行npm update命令 2.再执行npm outdated不应该有任何输出

如何卸载本地安装的包

删除node_modules目录下的package npm uninstall <package> 如需从package.json中删除依赖 npm uninstall --save <package> 注意:如果你将安装的包作为 "devDependency"(也就是通过 --save-dev 参数保存的),那么 --save 无法将其从 package.json 文件中删除。所以必须通过 --save-dev 参数可以将其卸载。

新全局包

npm update -g <package>`
 检查哪些包过期
 `npm outdated -g --depth=0`
 更新所有全局包
 `npm update -g

卸载全局包

npm uninstall -g <package>

如何创建node.js模块(发包)

node.js模块是可以发布到npm的包,当你创建一个新模块时,创建package.json是第一步。 1.npm init 创建package.json文件(name ,version 必填)-->2.index.js(模块的入口文件)-->3.在index.js中添加一个函数,作为exports对象的一个属性--->4.require此文件之后,这个函数在其他代码中可用。

exports.printMsg = function(){
console.log("2018/11/6");
}

如何发布或者更新package(发包)

任何含有package.json的文件夹都可以被发布。

怎样发包

1.了解规则

开始之前,最好去看下npm政策,去了解网站的规则,命名规则,权限之类的限制。

2.创建一个用户账户

如果想发包,首先你必须是npm的注册用户。 假如不是,用npm adduser创建一个,是的话直接login。 terminal: 测试自己是否已经登录npm whoami 注册npm adduser 登录npm login 终端操作之后登录https://npmjs.com/~username就能看到你自己的账户。

3.确定package里面涵盖了你想要的所有信息。

包名: 名字不能重复,尽量描述性。 规定:

  • 不能重名

  • 拼写也不要像似,容易拼写错误。

  • 你的名字不要让人误解不知道它的作者是谁。

  • 符合npm政策指南。 例如,不要将您的包命名为冒犯性的,也不要使用其他人的商标名称。

  • 在package.json文件的相应行中指定名称。

  • 如果你使用scope,前三条不适用。

包含readme.md文档

npm建议你在文件夹里包含一个readme文件来记录解释你的package温建名规定叫readme.md,扩展名.md表明它是一个markdown文件,当有人搜索到你的package时,这个文档将会在npm网站上展现。 开始之前,看看人家的readme是怎么写的,理解他的重要性。

  1. 创建一个文件,用什么editor都行。 2.将它命名为readme.md,存在项目文件夹里。 3.发布之后,人们想要download你的package时会看到它。

发布

npm publish Use npm publish to publish the package. 去https://npmjs.com/package/<package>就能看到发的包了。

怎么update

改版本号: npm version <update_type> 其中<update_type>是语义版本控制版本之一,补丁,次要或主要版本。 这句命令会改变package.json里面的版本号。 如果关联了git,这也会将更新后的版本号添加到您的git存储库中。 更新之后,再次runnpm publishhttps://npmjs.com/package/<package>检查版本号应该已经被更新。

怎么更新readme

npm version patch`
 `npm publish

如何使用语义化版本

在新版本的代码中说明更改的范围非常重要,因为有时更新会影响到package之间的依赖关系,语义版本控制(semver)是旨在解决此问题的标准。

Semver for publishers

如果你的项目要和别人分享,版本应该从1.0.0开始。 大小版本号更新按照如下的规矩:

image.png

如何使用scoped的包

需要npm版本在2以上

scope用来把相关联的包分组管理,为npm modules创建命名空间,比如一个domain。 名字以@开头的package是scoped package.范围是@和斜杠之间的所有内容。 例如: @username/project-name每个npm用户都有他自己的scope 想学习更多的scope相关知识,去这里https://docs.npmjs.com/misc/scope#publishing-public-scoped-packages-to-the-public-npm-registry

怎么初始化scoped package
{
  "name":"@username/project-name"
}

如果使用npm init,可以使用命令行添加。 npm init --scope=username 如果您始终使用相同的范围,则可能需要在.npmrc文件中设置此选项。 npm config set scope username

发布scoped package

默认情况下,scoped package是私有的,想发私有module 的话,需要充值成为私有模块用户~~~~~emm 公共范围模块是免费的,不需要付费订阅。 要发布公共范围模块,请在发布时设置访问选项。 此选项将保留为所有后续发布设置。 npm publish --access=public

使用scoped package

要使用scoped package ,只要当使用包的时候在名称里加上范围。 package.json

{
  "dependencies":{
      "@username/project-name":"1.0.0"
    }
}

终端输入: npm install @username/project-name --save 引用时:

var projectName = require ("@username/project-name")

如何使用dist-tag标记包

分布标签(dist-tags)补充语义版本控制(例如,v0.12)。 使用它们来组织和标记不同版本的包。 除了比semver编号更具人性可读性之外,标签还允许发布者更有效地分发他们的包。

添加tag

将标记添加到包的特定版本: npm dist-tag add <pkg>@<version> [<tag>]

使用标签发布:

默认情况下,npm发包会使用最近一次的tag。如果你使用--tag标记,你可以指定一个tag使用。例如: npm publish --tag beta

使用标签install

同publish,npm install<pkg>默认使用最近一次的tag 。要重载此行为,使用: npm install <pkg>@<tag>. 例如npm install somepkg@beta

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容

  • NPM官方文档写的十分良心,此篇我做一些比较常用功能的积累,有些地方是翻译,有些地方省略可以去官文看。 NPM是什...
    宋乐怡阅读 2,389评论 0 2
  • NPM NPM 是随同 Node 一起安装的包管理工具,能解决 Node 代码部署上的很多问题,常见的使用场景有以...
    heyi_let阅读 2,568评论 0 2
  • 什么是 NPM npm之于Node,就像pip之于Python,gem之于Ruby,composer之于PHP。 ...
    ihoey阅读 6,248评论 2 36
  • 描述 npm从以下来源获取配置值,按优先级排序: 命令行标记 在命令行上放置--foo bar设置foo配置参数为...
    竹天亮阅读 44,056评论 0 8
  • 必读小知识:eos交易速度快,无使用费用。不过,新建钱包需要一点费用,建好之后需要用eos抵押获得一定的cpu带宽...
    PsiNara阅读 329评论 0 0