我的Node.js学习之路(二)NPM模块管理


Posted in Javascript onJuly 06, 2014

NPM是一个Node包管理和分发工具,已经成为了非官方的发布Node模块(包)的标准。有了NPM,可以很快的找到特定服务要使用的包,进行下载、安装以及管理已经安装的包。

NPM常用的命令有:

      (1)$ npm install moduleNames
               安装Node模块
               注意事项:如果在使用模块的时候不知道其名字,可以通过http://search.npmjs.org网站按照
                                索引值找到想要的模块。npm也提供了查询的功能  $ npm search indexName
                                 安装完毕后会产生一个node_modules目录,其目录下就是安装的各个node模块。
                                 node的安装分为全局模式和本地模式。一般情况下会以本地模式运行,包会被安装
                                到和你的应用代码统计的本地node_modules目录下。在全局模式下,Node包会被
                                安装到Node的安装目录下的node_modules下。全局安装命令为
                                $ npm install -g moduleName。获知使用$npm set global=true来设定安装模式
                              ,$npm get global可以查看当前使用的安装模式。

      (2)$ npm view moduleNames
                 查看node模块的package.json文件夹
                注意事项:如果想要查看package.json文件夹下某个标签的内容,可以使用
                                 $ npm view moduleName labelName

     (3)$ npm list
                查看当前目录下已安装的node包
                注意事项:Node模块搜索是从代码执行的当前目录开始的,搜索结果取决于当前使用的目录中
                                 的node_modules下的内容。$ npm list parseable=true可以目录的形式来展现当
                                 前安装的所有node包

      (4)$ npm help
                查看帮助命令

     (5)$ npm view moudleName dependencies
                查看包的依赖关系

     (6)$ npm view moduleName repository.url
               查看包的源文件地址

      (7)$ npm view moduleName engines
               查看包所依赖的Node的版本 

     (8)$npm help folders
                查看npm使用的所有文件夹

      (9)$ npm rebuild moduleName
                用于更改包内容后进行重建

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

      (11)$ npm update moduleName
                     更新node模块

     (12)$ npm uninstall moudleName
                      卸载node模块

      (13)一个npm包是包含了package.json的文件夹,package.json描述了这个文件夹的结构。访
                      问npm的json文件夹的方法如下:
                            $ npm help json
                      此命令会以默认的方式打开一个网页,如果更改了默认打开程序则可能不会以网页的形式打
                      开。

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

      (15)很多时候我们在使用一个npm包的时候经常会忘记了require其相互依赖的模块,我们可以
                     借助如如下命令来查看此模块相互依赖的包都有哪些
 
 npm是Node.JS的程序包管理器。进行Node.JS开发时,经常使用它安装/卸载程序包。实际上,发布程序包的工作也是由它来完成的。

配置package.json

要打包程序,首先要配好各项设置,这些设置都由程序包根目录下的package.json指定。package.json的内容必须是严格的JSON格式,也就是说:

字符串要用双引号括起来,而不能用单引号;
属性名一定要加双引号;
最后一个属性后千万不要多加一个逗号。
配置对象的属性很多,具体可以参阅这里,这里列一下常用的项目:

name:程序包名,不能跟已有的程序包重复。
version:版本号。
description:一段简短的介绍。
author:作者信息。包含name、email、url三项属性。
bin:如果程序中有可执行文件(主要是命令行里面调用的),就在这里指定,可以指定多个。
main:使用require调用本程序包时的程序入口。
dependencies:依赖的程序包,可以指定版本号。

配置好package.json后,可以先在本地打包安装一次,测试程序运作是否正常,安装命令为:

npm install <本地路径>

另外,还有一条潜规则要注意,如果你希望程序包中的可执行程序在Node.JS的环境中运行,那么,请在程序入口文件的最前面加上这样一行:

#!/usr/bin/env node

如果没有这一行,它将以系统默认的方式打开,而不是在Node.JS的环境中运行。

注册npm帐号

要把程序包发布到npm,还需要先注册一个帐号。npm并没有提供网页版的注册向导。注册也要通过命令行来进行:

npm adduser
执行此命令后,会依次出现输入用户名、Email、密码的提示,输入好之后等待一会儿就可以了。

发布程序包

准备工作都做好了,执行下面的命令就可以发布程序包:

npm publish <本地路径>
如果要更新程序包,只要修改一下package.json中的版本号,再重新执行发布命令就可以了。

Javascript 相关文章推荐
判断iframe是否加载完成的完美方法
Jan 07 Javascript
JavaScript之appendChild、insertBefore和insertAfter使用说明
Dec 30 Javascript
js实现拖拽 闭包函数详细介绍
Nov 25 Javascript
javascript 广告移动特效的实现代码
Jun 25 Javascript
Angular多选、全选、批量选择操作实例代码
Mar 10 Javascript
EasyUI创建人员树的实例代码
Sep 15 Javascript
vue-cli脚手架-bulid下的配置文件
Mar 27 Javascript
js使用cookie实现记住用户名功能示例
Jun 13 Javascript
layer.js open 隐藏滚动条的例子
Sep 05 Javascript
React-redux实现小案例(todolist)的过程
Sep 29 Javascript
JavaScript相等运算符的九条规则示例详解
Oct 20 Javascript
node.JS事件机制与events事件模块的使用方法详解
Feb 06 Javascript
我的Node.js学习之路(一)
Jul 06 #Javascript
javascript数组操作方法小结和3个属性详细介绍
Jul 05 #Javascript
jQuery打印指定区域Html页面并自动分页
Jul 04 #Javascript
jQuery 仿百度输入标签插件附效果图
Jul 04 #Javascript
动态载入js提高网页打开速度的方法
Jul 04 #Javascript
JS中getYear()和getFullYear()区别分析
Jul 04 #Javascript
兼容IE、firefox以及chrome的js获取时间(getFullYear)
Jul 04 #Javascript
You might like
PHP PDOStatement::getColumnMeta讲解
2019/02/01 PHP
php实现简单四则运算器
2020/11/29 PHP
Jquery下attr和removeAttr的使用方法
2010/12/28 Javascript
Javascript面向对象之四 继承
2011/02/08 Javascript
javascript 弹出的窗口返回值给父窗口具体实现
2013/11/23 Javascript
javascript的tab切换原理与效果实现方法
2015/01/10 Javascript
javascript关于运动的各种问题经典总结
2015/04/27 Javascript
IONIC自定义subheader的最佳解决方案
2016/09/22 Javascript
AngularJS实践之使用NgModelController进行数据绑定
2016/10/08 Javascript
Vue.js系列之vue-router(上)(3)
2017/01/03 Javascript
JavaScript之Canvas_动力节点Java学院整理
2017/07/04 Javascript
nodejs实现套接字服务功能详解
2018/06/21 NodeJs
vue单页面实现当前页面刷新或跳转时提示保存
2018/11/02 Javascript
微信小程序实现发送验证码按钮效果
2018/12/20 Javascript
详解Node.JS模块 process
2020/08/31 Javascript
Jupyter中直接显示Matplotlib的图形方法
2018/05/24 Python
使用Puppeteer爬取微信文章的实现
2020/02/11 Python
安纳塔拉酒店度假村及水疗官方网站:Anantara Hotel
2016/08/25 全球购物
美国顶尖折扣时尚购物网:Bluefly
2016/08/28 全球购物
The Body Shop美体小铺西班牙官网:天然化妆品
2019/06/21 全球购物
草船借箭教学反思
2014/02/03 职场文书
工程质量承诺书范文
2014/03/27 职场文书
五心教育心得体会
2014/09/04 职场文书
纪念一二九运动演讲稿
2014/09/16 职场文书
2014年超市工作总结
2014/11/19 职场文书
师德先进个人材料
2014/12/20 职场文书
离婚协议书格式
2015/01/26 职场文书
2015年生产车间工作总结
2015/04/22 职场文书
社区低保工作总结2015
2015/07/23 职场文书
2016婚礼主持词开场白
2015/11/24 职场文书
工作简历的自我评价
2019/05/16 职场文书
Python 高级库15 个让新手爱不释手(推荐)
2021/05/15 Python
java如何实现socket连接方法封装
2021/09/25 Java/Android
工厂无线对讲系统解决方案
2022/02/18 无线电
pnpm对npm及yarn降维打击详解
2022/08/05 Javascript
CSS 鼠标点击拖拽效果的实现代码
2022/12/24 HTML / CSS