Node.js 的模块知识汇总


Posted in Javascript onAugust 16, 2017

在写 Node.js 应用程序的时候,你确实可以把所有代码放在巨大原 index.js 文件中,不在乎你的应用程序会变得多大多复杂。Node.js 解释器不会在意这个事情。但在代码组织方面,你很快就会陷入混乱,不能理解代码,而且难以调试。所以,作为一个人,你应该关心代码的结构。这就是使用模块的原因。

你可以把 Node.js 模块当作 JavaScript 库 —— 是整体代码中你想放在一起的某个部分(比如,函数集),你会想把这部分代码相对独立于代码库中的其它部分,可以把事情区分清楚。

就们我们把袜子放在衣柜一个抽屉,把衬衣放在衣柜的另一个抽屉 —— 我们可以把它们组成一天的着装 ——在代码库中,我们将不同的部分保存在不同的模块中,然后将它们有条不紊地合并成一个应用程序。

内建模块

即使我们不创造任何 Node.js 模块,也有模块可用,因为 Node.js 环境提供了内建模块。我们已经遇到过一个模块,就是在博客中寻找如何使用内建的 SHATWG URL 解析器的时候。

在我们自己的代码文件中,我们需要使用已经存在但是在别处声明的代码 —— 这种情况下,URL类是 Node.js 内置模块url中的一部分。

var URL = require('url').URL;

require('url')让我们可以访问url模块。这个模块定义在哪里,是怎么定义的,对我们来说完全不透明 —— 我们所需要知道的只是它的名称 ——url—— 以及它公开的属性,比如URL。

其它内建的模块直接导出我们需要的属性(通常是 JavaScript 对象)。以http模块为例:

var http = require('http');

http.createServer(function (req, res) {
  res.writeHead(200, {'Content-Type': 'text/html'});
  res.end('Hello World!');
}).listen(8080);

这里,请求http模块让我们可以直接访问http对象,我们可以直接使用其方法,比如createServer。

Node 初学者这本书讲述了如何使用 Node.js 写一个完整的 Web 服务器,它就是使用的内建http模块。

外部模块

内建模块随 Node.js 发布,它可以解决很多开发问题,而不需要为每个应用发明新的轮子,但是真正促进 Node.js 编程能力的是由来自 Node.js 社区的开源模块构建起来的庞大生态系统。这些模块也可以集成到我们的代码库中,但是由于它们不是内置的,并且不会随每次安装Node.js 一起安装,所以只在是我们的代码中require是不够的。我们需要先安装包含外部模块的代码库,由于 NPM,Node Package Manager(Node 包管理器) 的存在,这很容易。

请参博客文章,它以如何使用 async 库为例来介绍如何使用外部模块。

此外,Node工匠书还使用了一个章节来介绍了使用 NPM 的细节。

创建你自己的模块

内建模块和外部模块都是别人提供的,但它们不会妨碍你创建自己的 Node.js 模块。

下面的例子创建了一个名为myRandom的模块,它会提供了一个辅助函数,用于返回 0 到 10 之间的数。

文件myRandom.js:

function getRandom(min, max) {
   return Math.random() * (max - min) + min;
}

exports.between1and10 = function() {
   return getRandom(1, 10);
};

你应该把代码放在自己的myRandom.js文件中。由于此文件存在,并通过exports向外提供属性,另一个文件index.js可以使用导出的功能:

文件index.js:

var myRandom = require('./myRandom.js');

console.log(myRandom.between1and10());

require再次发挥作用,它让本地myRandom模块中导出的属性生效 —— 在这里是指between1and10函数。

注意:虽然模块系统允许公开模块的功能,但它也允许隐藏在模块之外不会用到的功能,只要不通过exports导出就好。即使index.js文件请求了myRandom.js文件,它也不能访问未导出的getRandom函数:

var myRandom = require('./myRandom.js');

console.log(myRandom.getRandom(5, 99));

这会导致 TypeError: myRandom.getRandom is not a function.

通过将实现细节隐藏在模块中,只暴露出需要在其它代码中使用的部分,可以很好的组织你的代码。

Javascript 相关文章推荐
List the Stored Procedures in a SQL Server database
Jun 20 Javascript
javascript 面向对象全新理练之原型继承
Dec 03 Javascript
再谈javascript 动态添加样式规则 W3C校检
Dec 25 Javascript
js自动生成的元素与页面原有元素发生堆叠的解决方法
Oct 24 Javascript
js实现具有高亮显示效果的多级菜单代码
Sep 01 Javascript
基于jQuery实现的双11天猫拆红包抽奖效果
Dec 01 Javascript
JS中mouseup事件丢失的原因与解决办法
Jun 14 Javascript
angular json对象push到数组中的方法
Feb 27 Javascript
让你5分钟掌握9个JavaScript小技巧
Jun 09 Javascript
vue mounted组件的使用
Jun 18 Javascript
Vue2.0点击切换类名改变样式的方法
Aug 22 Javascript
浅谈vue引用静态资源需要注意的事项
Sep 28 Javascript
vue绑定设置属性的多种方式(5)
Aug 16 #Javascript
jQuery中each循环的跳出和结束实例
Aug 16 #jQuery
随机生成10个不重复的0-100的数字(实例讲解)
Aug 16 #Javascript
vue动态路由实现多级嵌套面包屑的思路与方法
Aug 16 #Javascript
基于js 本地存储(详解)
Aug 16 #Javascript
基于Vue实例生命周期(全面解析)
Aug 16 #Javascript
基于JQuery的Ajax方法使用详解
Aug 16 #jQuery
You might like
PHP统计目录下的文件总数及代码行数(去除注释及空行)
2011/01/17 PHP
PHP实现根据浏览器跳转不同语言页面代码
2013/08/02 PHP
php获得刚插入数据的id 的几种方法总结
2018/05/31 PHP
JavaScript 核心参考教程 内置对象
2009/10/13 Javascript
javascript跑马灯抽奖实例讲解
2020/04/17 Javascript
Vue.js每天必学之数据双向绑定
2016/09/05 Javascript
JavaScript制作弹出层效果
2016/12/02 Javascript
thinkphp标签实现bootsrtap轮播carousel实例代码
2017/02/19 Javascript
yii form 表单提交之前JS在提交按钮的验证方法
2017/03/15 Javascript
jQuery封装placeholder效果实现方法,让低版本浏览器支持该效果
2017/07/08 jQuery
微信小程序实现根据字母选择城市功能
2017/08/16 Javascript
webpack学习笔记之优化缓存、合并、懒加载
2017/08/24 Javascript
element-ui 中使用upload多文件上传只请求一次接口
2019/07/19 Javascript
JointJS JavaScript流程图绘制框架解析
2019/08/15 Javascript
微信小程序修改数组长度的问题的解决
2019/12/17 Javascript
JS数组的高级使用方法示例小结
2020/03/14 Javascript
举例详解Python中yield生成器的用法
2015/08/05 Python
Python selenium如何设置等待时间
2016/09/15 Python
python中利用zfill方法自动给数字前面补0
2018/04/10 Python
PYQT5实现控制台显示功能的方法
2019/06/25 Python
python gdal安装与简单使用
2019/08/01 Python
python字符串格式化方式解析
2019/10/19 Python
Tensorflow Summary用法学习笔记
2020/01/10 Python
详解基于Jupyter notebooks采用sklearn库实现多元回归方程编程
2020/03/25 Python
解决Python中导入自己写的类,被划红线,但不影响执行的问题
2020/07/13 Python
python模拟点击玩游戏的实例讲解
2020/11/26 Python
香港万宁官方海外旗舰店:香港健与美连锁店
2018/09/27 全球购物
高中毕业自我鉴定
2013/12/19 职场文书
安全生产承诺书
2014/03/26 职场文书
会员卡清退活动总结
2014/08/27 职场文书
上班迟到检讨书范文300字
2014/11/02 职场文书
事业单位年度考核评语
2014/12/31 职场文书
离职感谢信怎么写
2015/01/22 职场文书
PyTorch梯度裁剪避免训练loss nan的操作
2021/05/24 Python
Window server 2012 R2 AD域的组策略相关设置
2022/04/28 Servers
Mybatis 一级缓存和二级缓存原理区别
2022/09/23 Java/Android