第二章. node中的模块和require

一 什么是模块.     

      JavaScript诞生初,它只不过是一个网页的小脚本而已,没有人会想到它会发展到现在能有大量的库,工具,组件变得如此复杂,慢慢地javascript发展中,人们发现javascript有个先天的缺陷--缺少模块.

      在其他语言中,java有类,python有import, php 有include和require甚至比它底层的C也有include.而javascript只能通过 <script>标签引入,这种方式令代码变得杂乱,依赖变得不清晰,安全性也不好(全局变量容易被污染).

为了解决问题,node引入了模块这个概念(准确来说是CommonJS引入了模块).nodejs中的模块具有隔离作变量用域(包)防止变量污染和实习私有变量,开放接口和成员,提供外部引用,解决依赖不清晰的问题.

关于隔离和接口,在后面会再讲

二 node模块分类

node模块有下面几种:

    1.系统模块(核心模块):由nodejs自带提供,可以是用js或者C++编写的,已经经过编译的模块.
    2.文件模块(用户模块):由用户编写的.

    核心模块在源代码中已经编译了,以二进制文件存在,模块引入时可以直接加到内存,文件定位和编译都省略掉,并在路径分析中优先,所以速度是最快的.

    文件莫模块运行的时候动态加载,需要经过路径分析和文件定位,编译,速度一般比核心模块慢.

三 require 方法:

1.require作用:
    require方法是nodejs提供的用于引用模块的方法.例如我们需要引入文件模块,则使用下面代码

var mod = require(‘module_name‘)

    此句执行后,Node内部会载入内置模块或通过NPM安装的模块。require函数会返回一个对象,该对象公开的API可能是函数,对象,或者属性如函数,数组,甚至任意类型的JS对象。

2.后缀:

require 默认接受以下后缀:

1 .js 文件 node会通过fs模块同步方式读取文件内容,然后把它的文本内容进行编译并且执行.
2.json 文件 node会通过fs模块同步方式读取文件内容,并调用JSON.parse 返回执行JSON.parse后的json对象.
3.node 文件 这是C++编写文件  node会调用dlopen()方法加载编译后生出来的文件.

当文件不带后缀,node会依照 目录 .js .json .node 的顺序进行查找.如果所有模块路径都找不到该文件,则抛出异常.

3. 模块路径:

require方法接受下面的引用方式
1.require("模块名"),或者 require(‘目录/模块名‘) 不以./开头的相对路径
 如果模块名不是路径,也不是内置模块,Node将试图去当前目录的node_modules文件夹里搜索。如果当前目录的node_modules里没有找到,Node会从父目录的node_modules里搜索,这样递归下去直到根目录。如果找不到文件,则会抛出异常

2.require("./模块名")或者 require(‘./目录/模块名‘) , 以 ./开头的相对绝对路径
node会直接加载以node运行的工作目录为基准的该模块.如果模块不存在则抛出异常

3 require("/目录/模块名") 或者 require(‘F:/目录/模块名‘) 绝对路径
nodej会直接加载该模块.如果模块不存在则抛出异常

四.模块缓存

对于已加载的模块Node会缓存下来,而不必每次都重新搜索和编译执行。多次require的同个模块只会被执行一次,下面是一个示例

//modA.js

console.log(‘模块modA开始加载...‘)

exports = function() {

console.log(‘Hi‘)

}

console.log(‘模块modA加载完毕‘)

//init.js

var mod1 = require(‘./modA‘)

var mod2 = require(‘./modA‘)

console.log(mod1 === mod2)

命令行执行:

node init.js

输出如下

$node init.js                     
模块modA开始加载...          
模块modA加载完毕           
$                                      

可以看到虽然require了两次,但modA.js仍然只执行了一次。mod1和mod2是相同的,即两个引用都指向了同一个模块对象。

待续

时间: 2024-10-12 16:08:57

第二章. node中的模块和require的相关文章

Node中的模块系统

加载require var 自定义变量名称 = require('模块') 两个作用: 执行被加载模块的代码 得到被加载模块中的exports导出接口对象 导出exports node中是模块作用域,默认文件中所有成员只在当前文件模块有效 对于希望可以被其他模块访问的成员,我们就把这些成员都挂载到exports接口对象中就可以了. 导出单个成员(拿到的就是:函数,字符串) module.exports = 'hello' 导出多个成员(必须在对象中) module.exports={ add:f

Node中导入模块require和import??

转自:https://blog.csdn.net/wxl1555/article/details/80852326 S6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS规范,使用require引入模块,使用module.exports导出接口. 不把require和import整清楚,会在未来的标准编程中死的很难看. require时代的模块 node编程中最重要的思想之一就是模块,而正

Node中http模块详解(服务端篇)

Node中的Http Node中提供了http模块,其中封装了高效的http服务器和http客户端 http.server是一个基于事件的HTTP服务器,内部是由c++实现的,接口由JavaScript封装 http.request是一个HTTP客户端工具.用户向服务器发送数据. 下面就来分别得介绍一下http的服务端和客户端 一.HTTP服务器 http.Server实现的,它提供了一套封装级别很低的API,仅仅是流控制和简单的解析,所有的高层功能都需要通过它的接口,就像在前面的文章<Node

node中的模块

模块 编写稍大一点的程序时一般都会将代码模块化.在NodeJS中,一般将代码合理拆分到不同的JS文件中,每一个文件就是一个模块,而文件路径就是模块名. 在编写每个模块时,都有require.exports.module三个预先定义好的变量可供使用. require require函数用于在当前模块中加载和使用别的模块,传入一个模块名,返回一个模块导出对象.模块名可使用相对路径(以./开头),或者是绝对路径(以/或C:之类的盘符开头).另外,模块名中的.js扩展名可以省略.以下是一个例子. var

Node中的模块引入机制

1.如果模块在当前目录下,可以通过下面语句将模块引入进来,注意需要使用 "./"表示当前路径 const currency = require('./currency'); ←---- 用路径./表明模块跟程序脚本放在同一目录下 2.如果模块在当前目录的子目录下,可以加上子目录的名称,如下. const currency = require('./lib/currency'); 3.要求模块在文件系统中使用相对路径存放,对于组织程序特定的代码很有帮助,但对于想要在程序间共享或跟其他人共

node中glob模块

glob glob允许使用规则,从而获取对应规则匹配的文件 node的glob模块允许你使用 * 等符号,来写一个glob规则,像在shell里一样,获取匹配对应规则文件 安装 npm install glob 引用 const glob = require('glob') glob的三个参数: 1.需要进行匹配的文件的路径(有点类似于正则表达式) 2.option可选项,也可以不填写 3.回调函数,回调函数内部可以返回两个参数,一个是匹配成功后的结果会返回一个数组, 如果没有匹配上不会报错会返

node中fs模块 - fs.open() fs.read() fs.write() fs.close()

var fs = require('fs') fs.open('./a.txt', 'a+', function(err, fd) { // 打开文件后 创建缓冲区放置数据 var readBuf = Buffer.alloc(1024), // 读取多少字节 bufOffset = 0, readbufLength = readBuf.length, filePosition = 50; // 提供缓冲区的第50个字节开始 // 读取文件 fs.read(fd, readBuf, bufOff

Node中http模块详解(客户端篇)

上一篇说到了http模块的服务器篇,在这个文章里面我们讨论一下http模块的客户端篇 1.http客户端 http模块提供了两个函数http.request和http.get,功能是客户端向服务器端发送请求. 1.1 http.request http.request(options,callback)用于发起http请求,接收两个参数,options是一个类似关联数组的对象,里面包含一些请求的参数,callback表示请求后的回调.options常用的参数如下: 名称 含义 host 请求网站

Python算法教程第二章知识点:计时模块、字典与散哈希表、图与树的实现、成员查询、插入对象

本文目录:一.计时模块:二.字典与散哈希表:三.图与树的实现:四.成员查询:五.插入对象</br>一.计时模块(timeit.cProfile) import timeit timeit.timeit('x = 1 + 2') 既然学习算法,那么来计算程序所耗费的时间是重要的,但是需要注意:timeit()计时函数会多次运行相关的代码段并求得平均值,以提高计时的精准度,所以,我们需要预防早先的执行操作影响之后代码的执行.举个栗子:若我们执行排序算法,则只有第一次执行代码时是在随机的情况下计时,