NodeJS 模块开发及发布详解分享


Posted in NodeJs onMarch 07, 2012

比如前两天我需要使用hmac和sha1来做签名,就没有找到一个比较好用的模块,这时候就需要我们自己来实现相应的功能了。自己写完之后,再把它打包成一个模块分享给大家来用,即方便了其他人,又能让自己有点小小的成就感,实在是一件一举多得的好事情。接下来,我就为大家介绍一下如何封装一个NodeJS模块并把它分享给其他人。

NPM (Node Package Manager, http://npmjs.org ) 是 NodeJS 的模块管理软件,除 NodeJS 内置的核心模块外,其他模块的安装、卸载等管理操作都要通过 NPM 来进行,我们自己写的模块,就要发布到NPM上来供其他人使用。

接下来,我们做一个非常简单的模块 “hello”,这个模块的功能只有一个:提供一个参数 “name” ,它在控制台输出 “Hello name”。在开始之前,我们首先要把node和npm装好,安装方法在其官方网站都有介绍,这里就不再多说了。

首先,我们创建一个名为”hello”的目录,作为模块的主目录。进入该目录,开始我们的工作。

然后,写模块的核心代码,很简单,只有以下三行:

exports.Hello = function ( name ) { 
console.log( "Hello " + name ); 
}

把它保存为 hello.js。

NodeJS每个扩展模块中都有一个package.json文件,用来描述模块的一些基本属性,比如模块名称、作者、版本号等等。关于package.json写法的详细说明,可以使用 “npm help json” 命令来查看。

我们可以在模块主目录下执行 npm init 来生成一个最基本的package.json。按照命令的提示依次输入信息即可。以下是在 hello 目录下执行 npm init 并填入相关信息后的结果:

$ npm init 
Package name: (hello) //模块名字,npm init会自动取当前目录名作为默认名字,这里不需要改,直接确认即可 
Description: A example for write a module //模块说明 
Package version: (0.0.0) 0.0.1 //模块版本号,这个大家按自己习惯来定就可以 
Project homepage: (none) //模块的主页,如果有的话可以填在这里,也可以不填 
Project git repository: (none) //模块的git仓库,选填。npm的用户一般都使用github做为自己的git仓库 
Author name: Elmer Zhang //模块作者名字 
Author email: (none) freeboy6716@gmail.com //模块作者邮箱 
Author url: (none) http://www.elmerzhang.com //模块作者URL 
Main module/entry point: (none) hello.js //模块的入口文件,我们这里是hello.js 
Test command: (none) //测试脚本,选填 
What versions of node does it run on? (~v0.5.7) * //依赖的node版本号,我们这个脚本可以运行在任何版本的node上,因此填 * 
About to write to /home/elmer/hello/package.json 
// 以下是生成的package.json文件内容预览 
{ 
"author": "Elmer Zhang <freeboy6716@gmail.com> (http://www.elmerzhang.com)", 
"name": "hello", 
"description": "A example for write a module", 
"version": "0.0.1", 
"repository": { 
"url": "" 
}, 
"main": "hello.js", 
"engines": { 
"node": "*" 
}, 
"dependencies": {}, 
"devDependencies": {} 
} 
Is this ok? (yes) //对以上内容确认无误后,就可以直接回车确认了

到此为止,我们这个模块就写完了。这时hello目录下应该有两个文件:hello.js和package.json。

我们可以返回到hello的上级目录,来测试安装一下这个模块:

$ npm install hello/ 
hello@0.0.1 ./node_modules/hello

显示安装成功。简单的测试一下:
$ node 
> var Hello = require('hello').Hello; 
> Hello('world');

Hello world正确输出了”Hello world”。

接下来我们把它发布到NPM上。

首先,我们需要有一个NPM帐号,可以使用npm adduser来注册一个:

$ npm adduser 
Username: elmerzhang 
Password: 
Email: freeboy6716@gmail.com

简单三步,一个NPM用户注册成功。

最后回到 hello 根目录,执行一下npm publish,如果没有任何错误提示,那么就发布成功了。去 http://search.npmjs.org/上看一下吧,你的模块应该已经显示在”Latest Updates”一栏里了。

至此,一个NodeJS模块成功发布到NPM,以后就可以在任何能访问npm库的地方通过npm install来安装你的模块了。

NodeJs 相关文章推荐
NodeJS学习笔记之网络编程
Aug 03 NodeJs
浅谈NodeJS中require路径问题
May 07 NodeJs
详解nodejs与javascript中的aes加密
May 22 NodeJs
NodeJS和BootStrap分页效果的实现代码
Nov 07 NodeJs
详解nodejs 文本操作模块-fs模块(四)
Dec 22 NodeJs
nodejs爬虫遇到的乱码问题汇总
Apr 07 NodeJs
Nodejs实现文件上传的示例代码
Sep 26 NodeJs
nodejs操作mongodb的增删改查功能实例
Nov 09 NodeJs
Mac下通过brew安装指定版本的nodejs教程
May 17 NodeJs
nodejs 使用 js 模块的方法实例详解
Dec 04 NodeJs
typescript nodejs 依赖注入实现方法代码详解
Jul 21 NodeJs
nodejs简单抓包工具使用详解
Aug 23 NodeJs
golang、python、php、c++、c、java、Nodejs性能对比
Mar 12 #NodeJs
PHPStorm 2020.1 调试 Nodejs的多种方法详解
Sep 17 #NodeJs
nodejs实用示例 缩址还原
Dec 28 #NodeJs
nodejs 后缀名判断限制代码
Mar 31 #NodeJs
NodeJS框架Express的模板视图机制分析
Jul 19 #NodeJs
用nodejs访问ActiveX对象,以操作Access数据库为例。
Dec 15 #NodeJs
nodejs入门详解(多篇文章结合)
Mar 07 #NodeJs
You might like
php下实现折线图效果的代码
2007/04/28 PHP
网页上facebook分享功能具体实现
2014/01/26 PHP
Yii入门教程之目录结构、入口文件及路由设置
2014/11/25 PHP
PHP使用递归方式列出当前目录下所有文件的方法
2015/06/02 PHP
PHP读取PPT文件的方法
2015/12/10 PHP
Laravel框架使用Redis的方法详解
2018/05/30 PHP
javascript实现面向对象类的功能书写技巧
2010/03/07 Javascript
jquery select动态加载选择(兼容各种浏览器)
2013/02/01 Javascript
JS链式调用的实现方法
2013/03/07 Javascript
javascript使用location.search的示例
2013/11/05 Javascript
javascript操作css属性
2013/12/30 Javascript
javascript中Number对象的toString()方法分析
2014/12/20 Javascript
javascript中mouseover、mouseout使用详解
2015/07/19 Javascript
headjs实现网站并行加载但顺序执行JS
2016/11/29 Javascript
基于JS设计12306登录页面
2016/12/28 Javascript
JavaScript实现旋转轮播图
2020/08/18 Javascript
浅谈Angular 中何时取消订阅
2017/11/22 Javascript
Vue+Vux项目实践完整代码
2017/11/30 Javascript
在微信小程序中保存网络图片
2019/02/12 Javascript
React如何实现浏览器打印部分内容详析
2019/05/19 Javascript
layer弹出层自定义提交取消按钮的例子
2019/09/10 Javascript
Nodejs + Websocket 指定发送及群聊的实现
2020/01/09 NodeJs
jquery选择器和属性对象的操作实例分析
2020/01/10 jQuery
完美解决python遍历删除字典里值为空的元素报错问题
2016/09/11 Python
Python 创建空的list,以及append用法讲解
2018/05/04 Python
可能是最全面的 Python 字符串拼接总结【收藏】
2018/07/09 Python
简单了解python filter、map、reduce的区别
2020/01/14 Python
Jupyter Notebook折叠输出的内容实例
2020/04/22 Python
Keras: model实现固定部分layer,训练部分layer操作
2020/06/28 Python
使用Vue.js和MJML创建响应式电子邮件
2021/03/23 Vue.js
幼儿园教师演讲稿
2014/05/06 职场文书
学前班语言教学计划
2015/01/20 职场文书
市场部岗位职责
2015/02/12 职场文书
2016大学先进团支部事迹材料
2016/03/01 职场文书
公司要求试用期员工提交“述职报告”,该怎么写?
2019/07/17 职场文书
JavaScript 原型与原型链详情
2021/11/02 Javascript