NodeJS遵循commonJs的语法规范
- 引入:require()
- 导出:module.exports或者exports
Node中的模块化
- 在Node中,一个JS就是一个模块
- 在Node中,每一个JS文件的js代码都是独立运行在一个函数中,而不是全局作用域
- 怎么证明是一个函数呢?我们可以输出只有函数有的:
console.log(arguments)
- 当我们输出
console.log(arguments.callee + '')
,就会发现,输出的是一个函数。(arguments.callee保存的就是当前的函数)
- 这个函数就长这样:
// exports:该对象用来将变量或者喊出暴露到外部
// require:函数,用来引入外部模块
// module:module代表的是当前的模块本身,exports就是module的一个属性。所以我们即可以使用exports导出也可以使用module.exports导出
// __filename:当前文件的一个完整路径
// __dirname:当前文件所在的文件夹的路径
function (exports, require, module, __filename, __dirname) {
// 我在01_module.js输出的,显示的就是我当前js文件这个函数
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
// 01_module.js----引入
const md = require('./02_module')
const fs = require('fs')
console.log(md.name)
console.log(md.num)
console.log(md.sayHi())
// 02_module.js----导出
console.log(111111)
// exports导出
exports.name = '模块2中的A'
exports.num = 1000
exports.sayHi = function() {
console.log(`大家好`)
}
// module.exports导出方式1
module.exports.name = '模块2中的A'
module.exports.num = 1000
module.exports.sayHi = function() {
console.log(`大家好`)
}
// module.exports导出方式2
module.exports = {
name: '模块2中的A',
num: 1000,
sayHi: function() {
console.log(`大家好`)
}
}