快速掌握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 相关文章推荐
JQuery 构建客户/服务分离的链接模型中Table中的排序分析
Jan 22 Javascript
javascript包装对象实例分析
Mar 27 Javascript
JavaScript中boolean类型之三种情景实例代码
Nov 21 Javascript
js获取当前时间(昨天、今天、明天)
Nov 23 Javascript
详解js树形控件—zTree使用总结
Dec 28 Javascript
ES6中module模块化开发实例浅析
Apr 06 Javascript
Angular2关于@angular/cli默认端口号配置的问题
Jul 15 Javascript
原生js中ajax访问的实例详解
Sep 19 Javascript
基于Vue的SPA动态修改页面title的方法(推荐)
Jan 02 Javascript
微信小程序实现换肤功能
Mar 14 Javascript
vue.js打包之后可能会遇到的坑!
Jun 03 Javascript
详解vue中async-await的使用误区
Dec 05 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
MySQL修改密码方法总结
2008/03/25 PHP
PHP 配置文件中open_basedir选项作用
2009/07/19 PHP
javascript 点击整页变灰的效果(可做退出效果)。
2008/01/09 Javascript
基于Jquery的动态创建DOM元素的代码
2010/12/28 Javascript
jquery删除指定的html标签并保留标签内文本内容的方法
2014/04/02 Javascript
node.js中的fs.statSync方法使用说明
2014/12/16 Javascript
使用JavaScript和CSS实现文本隔行换色的方法
2015/11/04 Javascript
一道常被人轻视的web前端常见面试题(JS)
2016/02/15 Javascript
使用jQuery制作浮动工具栏的实例分享
2016/05/13 Javascript
javascript作用域、作用域链(菜鸟必看)
2016/06/16 Javascript
微信小程序开发教程-手势解锁实例
2017/01/06 Javascript
ionic+AngularJs实现获取验证码倒计时按钮
2017/04/22 Javascript
详解Vue中过度动画效果应用
2017/05/25 Javascript
JS实现前端缓存的方法
2017/09/21 Javascript
AngularJS的$location使用方法详解
2017/10/19 Javascript
VUE element-ui 写个复用Table组件的示例代码
2017/11/18 Javascript
基于JavaScript中字符串的match与replace方法(详解)
2017/12/04 Javascript
Vue2(三)实现子菜单展开收缩,带动画效果实现方法
2019/04/28 Javascript
Flexible.js可伸缩布局实现方法详解
2020/11/13 Javascript
python中sleep函数用法实例分析
2015/04/29 Python
python简单图片操作:打开\显示\保存图像方法介绍
2017/11/23 Python
Python os.rename() 重命名目录和文件的示例
2018/10/25 Python
Python生成一个迭代器的实操方法
2019/06/18 Python
Python如何创建装饰器时保留函数元信息
2020/08/07 Python
Django2.1.7 查询数据返回json格式的实现
2020/12/29 Python
荷兰本土平价百货:HEMA
2017/10/23 全球购物
汽车运用工程系毕业生自荐信
2013/12/27 职场文书
小学生班会演讲稿
2014/01/09 职场文书
学生出入校管理制度
2014/01/16 职场文书
大学生心理活动总结
2014/07/04 职场文书
领导班子整改方案和个人整改措施
2014/10/25 职场文书
企业财务总监岗位职责
2015/04/03 职场文书
上课迟到检讨书范文
2015/05/06 职场文书
硕士论文致谢范文
2015/05/14 职场文书
北京爱情故事观后感
2015/06/12 职场文书
Java并发编程之原子性-Atomic的使用
2022/03/16 Java/Android