博客
关于我
Node:模块
阅读量:340 次
发布时间:2019-03-04

本文共 2391 字,大约阅读时间需要 7 分钟。

核心模块

描述

Node为JavaScript提供了很多服务器级别的API,这些API绝大多数都被包装到了一个具名的核心模块中。例如文件操作的fs核心模块,http服务构建的http模块,path路径操作模块,os操作系统信息模块。。。。
这些核心模块在使用时必须通过require()来加载模块

NodeJs API文档:

实例:以fs模块为例

读取文件

//使用reqire方法加载fs核心模块var fs=require('fs')//读取文件fs.readFile('./helloworld.txt',function(errir,data){   	console.log(data)})

介绍:

fs是file-system的简写,是文件系统的意思在node中如果想要进行文件操作,就必须引入fs这个模块在这个模块中提供了所有文件操作的相关apireadFile(path,callback)读取文件的函数path是要读取的文件路径callback回调函数:	参数一:error  参数二:data如果读取成功error就是null,data就是文件内的数据如果读取失败error就是错误对,data就是undefined

结果:

在这里插入图片描述
文件存储的都是2进制数据,返回的是16进制(2进制转为了16进制)
可以通过toString方法转换为正常的文字

console.log(data.toString())

写文件

//使用reqire方法加载fs核心模块var fs=require('fs')//写文件fs.writeFile('./helloworld.txt','你好,世界',function(error){   	console.log("文件写入成功")})
writeFile(path,data,callback)path文件路径,data要写入的内容,callback回调函数回调函数参数error,文件写入成功error是null,文件写入失败error是错误对象

自定义模块

描述:

我们自己写.js文件就是一个模块

实例:加载并执行其它模块

a.js

console.log("a.js开始执行")require('./b.js')var name = "a.js"console.log('name:',name)console.log("a.js执行结束")

b.js

console.log("b.js开始执行")var name = "b.js"console.log("b.js执行结束")

结果:

在这里插入图片描述
注:
1、相对路径必须加 ./
2、node中没有全局作用域,只有模块作用域,作用域中的变量互不影响,也不能调用另一个模块中的函数
3、除了已经定义好的核心模块,自己写的js文件也是模块

模块通信

有时候我们加载另一个模块并不是执行另一个模块中的内容,而是为了使用里面的某个成员
那么如何进行模块间的通信?这里还是依靠require函数

require函数有两个作用:

  • 加载文件模块并执行里面的代码
  • 获得被加载文件模块导出的接口对象

每个文件模块中都提供了一个对象:exports,该对象默认是一个空对象,可以将杨使用的成员写入这个对象

//a.jsconsole.log("a.js开始执行")var obj = require('./b.js')console.log("加法:", obj.add(4, 5))console.log("乘法:", obj.mult(4, 5))console.log("a.js执行结束")//b.jsmodule.exports = {   	add: function(a, b) {   		return a + b	},	mult: function(a, b) {   		return a * b	}}

在这里插入图片描述

如果仅仅是导出一个对象,可以直接 module.exports = 值
例如:

module.exports = 'hello'那么通过require获取的值就是hello

注:module.exports 只能赋值一次,再次赋值会覆盖前面的内容,如果要导出多个对象就用对象的方式

补充:

1、 除了使用module.exports导出外还可以直接`exports=值

这种方式可以重复赋值,但是无论是赋值一次还是赋值多次,当通过require来获取时,都会获取到一个对象。而module.exports 你赋值一个对象,那就得到一个对象,赋值一个字符串那就得到一个字符串

exports.age = 15exports.show = function(){   }....

2、

3、require的加载规则:

  • 优先从缓存加载,可以拿到接口对象但是不会重复加载已经加载过的模块。
//main.jsrequire('./a.js')var b = require('./b.js')console.log("main.js:", b)//a.jsconsole.log("a.js被加载了")var b = require('./b.js')console.log("b.js:", b)//b.jsconsole.log("b.js被加载了")module.exports = "hello Node"

执行main.js

在这里插入图片描述
可以看出b.js中的代码只执行了一次,但是main.js 和 a.js 中都能得到b.js中导出的值

  • 判断模块标识
    • 加载路径形式的模块。 ./ 表示当前 目录不可省略; ../ 上一级目录,不可省略 ; .js 后缀可以省略

    • 核心模块。核心模块已经被编译到2进制文件中,只需要加载名字

    • 第三方模块。通过加载包名的形式加载,第三方包不可能和核心模块名相同

转载地址:http://rlgh.baihongyu.com/

你可能感兴趣的文章
Nginx 多端口配置和访问异常问题的排查与优化
查看>>
Nginx 如何代理转发传递真实 ip 地址?
查看>>
Nginx 学习总结(16)—— 动静分离、压缩、缓存、黑白名单、性能等内容温习
查看>>
Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
查看>>
Nginx 学习(一):Nginx 下载和启动
查看>>
nginx 常用指令配置总结
查看>>
Nginx 常用配置清单
查看>>
nginx 常用配置记录
查看>>
nginx 开启ssl模块 [emerg] the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx
查看>>
Nginx 我们必须知道的那些事
查看>>
Nginx 源码完全注释(11)ngx_spinlock
查看>>
Nginx 的 proxy_pass 使用简介
查看>>
Nginx 的 SSL 模块安装
查看>>
Nginx 的优化思路,并解析网站防盗链
查看>>
Nginx 的配置文件中的 keepalive 介绍
查看>>
nginx 禁止以ip形式访问服务器
查看>>
Nginx 结合 consul 实现动态负载均衡
查看>>
Nginx 负载均衡与权重配置解析
查看>>
Nginx 负载均衡详解
查看>>
nginx 配置 单页面应用的解决方案
查看>>