NodeJS遵循commonJs的语法规范
- 引入:require()
- 导出:module.exports或者exports
Node中的模块化
- 在Node中,一个JS就是一个模块
- 在Node中,每一个JS文件的js代码都是独立运行在一个函数中,而不是全局作用域
- 怎么证明是一个函数呢?我们可以输出只有函数有的:
console.log(arguments)
- 当我们输出
console.log(arguments.callee + ''),就会发现,输出的是一个函数。(arguments.callee保存的就是当前的函数)
- 这个函数就长这样:
function (exports, require, module, __filename, __dirname) {
const md = require('./02_module')
console.log(md.name)
console.log(md.num)
console.log(md.sayHi())
console.log(arguments.callee + '')
}
- 在Node中,一个模块中的变量和函数在其他函数中无法直接访问。我们可以通过exports或者module.exports向外部暴露变量和方法
- 在Node中,通过require()函数来引入外部模块
- require()可以传递一个文件的路径作为参数,Node将会自动根据该路径来引入外部模块
- 注意的是,这里的路径,如果使用相对路径,必须以./或者../开头,不能省略。
- 使用require()引入模块后,该函数返回一个对象,这个对象代表的就是引入的模块
简单说下module.exports和exports区别
- 其实exports = module.exports。
- exports只能使用
.的形式向外面暴露内部的变量
- module.exports既可以通过
.的形式,也可以使用直接赋值
mudule.exports.x = xxx
module.exports = {}
- 为什么exports不能使用直接赋值呢?这涉及到数据的类型和内存(数据存放位置)
NodeJS模块中分成两大类
- 核心模块
- 文件模块
- 由用户自己创建的模块
- 文件模块的标识,就是文件的路径。
简单的demo
const md = require('./02_module')
const fs = require('fs')
console.log(md.name)
console.log(md.num)
console.log(md.sayHi())
console.log(111111)
exports.name = '模块2中的A'
exports.num = 1000
exports.sayHi = function() {
console.log(`大家好`)
}
module.exports.name = '模块2中的A'
module.exports.num = 1000
module.exports.sayHi = function() {
console.log(`大家好`)
}
module.exports = {
name: '模块2中的A',
num: 1000,
sayHi: function() {
console.log(`大家好`)
}
}