CommonJS 就是为 JS 的表现来制定规范,由于 JS 没有模块系统,标准库较少,缺少包管理工具,因此 CommonJS 应运而生,它但愿 JS 能够在任何地方运行,而不仅是在浏览器中,从而达到 Java、C#、PHP 这些后端语言具有开发大型应用的能力。node
CommonJS 就是模块化的标准,Node.js 就是 CommonJS(模块化)的实现。后端
在 Node 中,模块分为两类:浏览器
一是 Node 提供的模块,称为核心模块,例如 http 模块、url 模块、fs 模块。bash
二是用户编写的模块,称为文件模块,好比接下来要新建一个 js 文件,并在里边添加的工具模块,经过 exports 或者 module.exports 将模块导出,并经过 require 引入这些模块。服务器
首先新建一个 js 文件,在里边添加工具模块,并暴露模块。模块化
暴露模块的方式有两种:工具
module.exports 是真正的接口,exports 是一个辅助工具。ui
若是 module.exports 为空,那么全部的 exports 收集到的属性和方法,都赋值给了 module.exports,若是 module.exports 具备任何属性和方法,则 exports 会被忽略。url
let str = "learning CommonJS";
exports.str = str; // {str: "learning CommonJS"}
复制代码
暴露出 tools 工具模块,经过 require 导入使用(与 url 模块和 http 模块的引入方式相同)。spa
在下面代码中咱们是用 module.exports 方式来暴露模块。
tools.js
const tools = {
length: (...numbers) => {
return numbers.length;
},
sum: (...numbers) => {
let sum = 0;
for (let number in numbers) {
sum += numbers[number]
};
return sum;
}
};
module.exports = tools;
复制代码
接下来再新建一个 js 文件,并引入刚编写的模块。
CommonJS.js
const tool = require('./tools.js')
const http = require('http');
const hostname = '127.0.0.1';
const port = 3000;
const server = http.createServer((request, response) => {
if (request.url != '/favicon.ico') {
console.log(tool.length(1,2,3));
console.log(tool.sum(1,2,3));
};
response.statusCode = 200;
response.setHeader('Content-Type', 'text/plain;charset=utf-8');
response.end('CommonJS,调取了 tool.js 工具模块中的 length() 和 sum() 两个方法。');
});
server.listen(port, hostname, () => {
console.log(`服务器运行在 http://${hostname}:${port}`);
});
复制代码
执行 node CommonJS.js,访问:127.0.0.1:3000/
3
6
复制代码