快速掌握Node.js模块封装及使用


Posted in Javascript onMarch 21, 2016

Node.js中也有一些功能的封装,类似C#的类库,封装成模块这样方便使用,安装之后用require()就能引入调用.

一、Node.js模块封装

 1.创建一个名为censorify的文件夹

 2.在censorify下创建3个文件censortext.js、package.json、README.md文件

1)、在censortext.js下输入一个过滤特定单词并用星号代替的函数。

var censoredWorlds=["sad","bad","mad"];
var custormCensoredWords=[];
function censor(inStr)
{
  for(idx in censoredWorlds)
  {
    inStr=inStr.replace(censoredWorlds[idx],"****");
  }
  for(idx in custormCensoredWords)
  {
    inStr=inStr.replace(custormCensoredWords[idx],"****");
  }
  return inStr;
}
 
function addCensoreWorld(world)
{
  custormCensoredWords.push(world);
}
 
function getCensoreWorlds()
{
  return censoredWorlds.concat(custormCensoredWords);
}
exports.censor=censor;
exports.addCensoreWorld=addCensoreWorld;
exports.getCensoreWorlds=getCensoreWorlds;

2)、在package中配置清单信息 例如版本 名称和main指令等。

{
 "author":"cuiyanwei",
 "name":"censority",
 "version":"0.1.1",
 "description":"Censors words out of text",
 "main":"censortext",
 "dependencies":{
  "express":"latest"
 },
 "enginee":{
  "node":"*"
 }
}

3)、创建的README.md文件主要是描述说明

3.使用命令行创建封装模块

使用命令行导航到censorify文件夹下,然后使用命令 npm pack 封装生成tgz文件,这样就封装了一个模块。

快速掌握Node.js模块封装及使用

二、封装模块的使用

封装模块的使用有两种方法 :发布到NPM注册表、本地使用,这里只记录下本地使用的方法.

1.创建名readwords文件夹

2.命令行导航到readwords文件夹下,然后安装已经封装好的模块,如果是已经发布到NPM注册表的直接 npm install 名字,如果是在本地 npm install tgz文件路径。

快速掌握Node.js模块封装及使用

3.安装完成后会在readwords文件夹下生成包含censority子文件夹的node_modules文件夹

快速掌握Node.js模块封装及使用

4.新建readwords.js文件测试(注意代码console、封装模块的函数别写错了)

var censor=require("censority");
console.log(censor.getCensoreWorlds());
console.log(censor.censor("Some very sad,bad and mad text"));
censor.addCensoreWorld("gloomy");
console.log(censor.getCensoreWorlds());
console.log(censor.censor("A very goolmy day."));

5.使用

用命令行node readwords.js来调用readwords.js查看结果

快速掌握Node.js模块封装及使用

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
下载网站打开页面后间隔多少时间才显示下载链接地址的代码
Apr 25 Javascript
纯css实现窗户玻璃雨滴逼真效果
Aug 23 Javascript
CKEditor无法验证的解决方案(js验证+jQuery Validate验证)
May 09 Javascript
jQuery根据name属性进行查找的用法分析
Jun 23 Javascript
jQuery基于ID调用指定iframe页面内的方法
Jul 06 Javascript
react-router4 嵌套路由的使用方法
Jul 24 Javascript
javascript简写常用的12个技巧(可以大大减少你的js代码量)
Mar 28 Javascript
js实现微信/QQ直接跳转到支付宝APP打开口令领红包功能
Jan 09 Javascript
Bootstrap popover 实现鼠标移入移除显示隐藏功能方法
Jan 24 Javascript
js实现控制文件拖拽并获取拖拽内容功能
Feb 17 Javascript
JavaScript碰撞检测原理及其实现代码
Mar 12 Javascript
详解阿里Node.js技术文档之process模块学习指南
Jan 04 Javascript
JS DOM实现鼠标滑动图片效果
Sep 17 #Javascript
实践中学习AngularJS表单
Mar 21 #Javascript
javascript单页面手势滑屏切换原理详解
Mar 21 #Javascript
javascript实现dom元素可拖动
Mar 21 #Javascript
AngularJS 中的指令实践开发指南(一)
Mar 20 #Javascript
浅析AngularJS中的指令
Mar 20 #Javascript
简述Matlab中size()函数的用法
Mar 20 #Javascript
You might like
图象函数中的中文显示
2006/10/09 PHP
php5.2.0内存管理改进
2007/01/22 PHP
php获取apk包信息的方法
2014/08/15 PHP
php判断输入是否是纯数字,英文,汉字的方法
2015/03/05 PHP
php实现与python进行socket通信的方法示例
2017/08/30 PHP
PHP实现Huffman编码/解码的示例代码
2018/04/20 PHP
jQuery AJAX回调函数this指向问题
2010/02/08 Javascript
jQuery 选择器理解
2010/03/16 Javascript
JavaScript高级程序设计 扩展--关于动态原型
2010/11/09 Javascript
JavaScript-RegExp对象只能使用一次问题解决方法
2014/06/23 Javascript
详谈jQuery unbind 删除绑定事件 / 移除标签方法
2017/03/02 Javascript
jQuery.form.js的使用详解
2017/06/14 jQuery
在layui中select更改后生效的方法
2019/09/05 Javascript
[03:42]2014DOTA2西雅图国际邀请赛 Navi战队巡礼
2014/07/07 DOTA
Python实现多并发访问网站功能示例
2017/06/19 Python
Python实现复杂对象转JSON的方法示例
2017/06/22 Python
解决python报错MemoryError的问题
2018/06/26 Python
python使用插值法画出平滑曲线
2018/12/15 Python
Django Channels 实现点对点实时聊天和消息推送功能
2019/07/17 Python
将自己的数据集制作成TFRecord格式教程
2020/02/17 Python
Python经纬度坐标转换为距离及角度的实现
2020/11/01 Python
css3中background新增的4个新的相关属性用法介绍
2013/09/26 HTML / CSS
春秋航空官方网站:Spring Airlines
2017/09/27 全球购物
亚洲最大的运动鞋寄售店:KicksCrew
2020/11/26 全球购物
面向对象设计的原则是什么
2013/02/13 面试题
专科毕业生学习生活的自我评价
2013/10/26 职场文书
2014年幼儿园元旦活动方案
2014/02/13 职场文书
派出所所长先进事迹
2014/05/19 职场文书
中学生纪念九一八事变演讲稿
2014/09/14 职场文书
2014年公务员退休工资改革方案
2014/10/01 职场文书
交通事故委托书范本精选
2014/10/04 职场文书
2014年电教工作总结
2014/12/19 职场文书
云台山导游词
2015/02/03 职场文书
白鹤梁导游词
2015/02/06 职场文书
2016廉洁从政心得体会
2016/01/19 职场文书
古诗之爱国古诗5首
2019/09/20 职场文书