npm 那些事儿

npm和node是现在前端开发必不可少的工具,尤其是随着前端模块化开发的流行,熟练使用npm,可以在开发中让你如鱼得水。下面我们一起来学习一下npm吧。

一、创建一个包,并且发布:

首先新建一个文件夹,名字自己随意,比如我的:npm-package-test,进入到该文件夹下,然后使用 npm init 命令进行初始化, 如下图:  

    

在命令行的提示下填写每一步的信息, 当然也可以直接按下回车,npm会自动为我们填写一些默认值的。

完成这一步之后,我们就会看到在文件夹下多了一个package.json文件,这个就是包的配置文件,里面与包名、版本号、描述信息、包的入口文件、可以执行的脚本、作者、许可证,以后在我们使用的过程中,还会接触到 devDependencies、dependencies、repository等等。

接下来,我们可以按照我们需要实现的功能,创建一些文件夹、文件。为了示例起见,我只创建了入口文件index.js.

二、添加用户

在第一步中,我们就简单的创建了一个包,这个包在以后是需要人来管理的,所以就需要添加用户。

这里,我们使用  npm adduser 命令:

输入该命令之后,我们需要输入一些基本信息,按着提示一步一步来就行。

三、发布

上一步完成之后,我们可以把我们的包发布到 npm仓库中,让更多的人来使用我们的包(这个除外。。。)。

直接使用 npm publish  命令一键搞定。

是不是很有成就感呢。

四、npm owner

这个命令主要是用来管理包的所有者,即哪些人有权限操作这个包。 通常,创建包的人, 默认就是这个包的第一个owner,如果这个时候想要删除owner,是删除不了的,只有当包的owner人数大于1的时候, 才可以选择删除owner。

npm owner add <username> <packagename>      #添加owner:

npm owner ls  <packagename>      #查看所有的owner

npm owner rm <user>  <packagename>     #移除一个owner

成为包的所有者的用户, 就可以修改包的代码,发布新版本,同时也可以添加其他用户。

五、npm insatll

npm install  #安装package.json文件中的的所有依赖

npm install  packagename  #安装packagename包

npm install  packagename@version  #安装版本号为version的packagename包

关于 -S或者--save:

在执行install命令的时候,会把包信息加入到package.json文件中的dependencies字段中,例如:

npm install webpack  --save

如果使用了-S 或者--save则表示这是一个生产环境会用到的一个依赖。

关于 -D 或者 --save-dev:

在执行install命令的时候,会把包信息加入到package.json文件中的devDependencies字段中,例如:

npm install webpack  --save-dev

如果使用了 -D或者--save-dev, 则表示这是一个在测试环境中使用的依赖;

关于 -O 或者 --save-optional:

在执行install命令的时候,会把包信息加入到package.json文件中的optionalDependencies字段中,例如:

npm install webpack  --save-optional

如果使用了-O或者--save-optional, 则表示这是一个可选阶段的依赖;

关于 -g 或者 --global

表示是全局安装,例如:

npm install webpack  -g

六、npm cache

npm cache add <tarball file>

npm cache add <folder>

npm cache add <tarball url>

npm cache add <name>@<version>

npm cache ls <path>

npm cache clean <path>

最常用的还是 npm cache clean

七、 npm config

npm config set <key> <value>  [-g|--global]

npm config get  <key>

npm config delete  <key>

npm config list

npm config edit

npm get <key>

npm set <key> [ -g|--global]

比如:

npm config  get  registry

npm config set proxy = http://dev-proxy.oa.com:8080

npm config set registry="http://r.cnpmjs.org"

八、 npm start

这个命令可以执行一个模块,命令写在package.json文件中的scripts属性中,命令名称可以由开发者自己配置。

"scripts": {

      "start" : "gulp -ws"

}

可以自己配置名称:

"scripts": {

       "ecWebpack" : "webpack  --config webpack.config.js"

}

当然执行的时候,就需要使用命令  npm ecWebpack了

九、 npm test

用来测试一个模块。命令写在package.json文件中的scripts属性中,命令名称可以由开发者自己配置。

"scripts": {

          "test" : "gulp -ws"

}

上面八和九中的start、test都是大家约定俗成的名称,开发者可以在自己的package.json文件中自定义。

十、其他命令

npm update <packagename>  #更新包

npm update <packagename>  #卸载包  (可以添加 --save , --save-dev等参数)

npm outdated <packagename>  #检查包是否过时

npm ls  #查看已经安装的模块

npm root  #查看包的安装路径

npm start  #启动模块(包)

npm stop  #停止模块(包)

npm restart #重新启动模块(包)

npm test  #测试模块(包)

npm version #查看包的版本 

npm view  #查看包的注册信息

参考链接:

http://www.8dou5che.com/2017/01/13/npm-cli/

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

推荐阅读更多精彩内容

  • npm是什么 NPM的全称是Node Package Manager,是随同NodeJS一起安装的包管理和分发工具...
    build1024阅读 7,854评论 0 9
  • 描述 npm从以下来源获取配置值,按优先级排序: 命令行标记 在命令行上放置--foo bar设置foo配置参数为...
    竹天亮阅读 44,049评论 0 8
  • 什么是 NPM npm之于Node,就像pip之于Python,gem之于Ruby,composer之于PHP。 ...
    ihoey阅读 6,247评论 2 36
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,594评论 18 139
  • 本文内容基于 npm 4.0.5 概述 npm (node package manager),即 node 包管理...
    静默虚空阅读 2,107评论 0 8