我的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 相关文章推荐
jQuery 使用手册(六)
Sep 23 Javascript
javascript 数字格式化输出的实现代码
Dec 10 Javascript
jQuery中复合属性选择器用法实例
Dec 31 Javascript
基于es6三点运算符的使用方法(实例讲解)
Oct 12 Javascript
JS实现留言板功能[楼层效果展示]
Dec 27 Javascript
vuex与组件联合使用的方法
May 10 Javascript
JS获取浏览器地址栏的多个参数值的任意值实例代码
Jul 24 Javascript
vue单页缓存存在的问题及解决方案(小结)
Sep 25 Javascript
vue相同路由跳转强制刷新该路由组件操作
Aug 05 Javascript
JavaScript检测是否开启了控制台(F12调试工具)
Oct 02 Javascript
Vue实现导入Excel功能步骤详解
Jul 03 Vue.js
如何vue使用el-table遍历循环表头和表体数据
Apr 26 Vue.js
我的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中的静态变量及static静态变量使用详解
2015/11/05 PHP
详解WordPress中添加和执行动作的函数使用方法
2015/12/29 PHP
php获取POST数据的三种方法实例详解
2016/12/20 PHP
ThinkPHP5.0框架控制器继承基类和自定义类示例
2018/05/25 PHP
laravel框架创建授权策略实例分析
2019/11/22 PHP
十分钟打造AutoComplete自动完成效果代码
2009/12/26 Javascript
js关闭父窗口时关闭子窗口
2013/04/01 Javascript
JavaScript伸缩的菜单简单示例
2013/12/03 Javascript
javaScript使用EL表达式的几种方式
2014/05/27 Javascript
基于JQuery实现仿网易邮箱全屏动感滚动插件fullPage
2015/09/20 Javascript
js针对ip地址、子网掩码、网关的逻辑性判断
2016/01/06 Javascript
JavaScript中使用数组方法汇总
2016/02/16 Javascript
jQuery simpleModal插件的使用介绍
2016/08/30 Javascript
javascript构造函数以及原型对象的理解
2017/01/13 Javascript
AngularJS之页面跳转Route实例代码
2017/03/10 Javascript
AngularJS入门教程一:路由用法初探
2017/05/27 Javascript
Vue-cli-webpack搭建斗鱼直播步骤详解
2017/11/17 Javascript
基于JS开发微信网页录音功能的实例代码
2019/04/30 Javascript
详解小程序input框失焦事件在提交事件前的处理
2019/05/05 Javascript
Vue实现点击按钮复制文本内容的例子
2019/11/09 Javascript
jQuery实现简单三级联动效果
2020/09/05 jQuery
Python正规则表达式学习指南
2016/08/02 Python
Flask框架的学习指南之开发环境搭建
2016/11/20 Python
详解django中使用定时任务的方法
2018/09/27 Python
Python使用Excel将数据写入多个sheet
2020/05/16 Python
python使用多线程+socket实现端口扫描
2020/05/28 Python
浅析Python 条件控制语句
2020/07/15 Python
Python加载数据的5种不同方式(收藏)
2020/11/13 Python
最耐用行李箱,一箱永流传:Briggs & Riley(全球终身保修)
2017/12/07 全球购物
可爱的童装和鞋子:Fabkids
2019/08/16 全球购物
翻译专业应届生求职信
2013/11/23 职场文书
设计师个人求职信范文
2014/02/02 职场文书
小摄影师教学反思
2014/04/27 职场文书
《我的伯父鲁迅先生》教学反思
2016/02/16 职场文书
MySQL系列之十一 日志记录
2021/07/02 MySQL
Mysql 数据库中的 redo log 和 binlog 写入策略
2022/04/26 MySQL