首页 > Web开发 > 详细

关于CommonJs规范

时间:2020-07-06 11:02:26      阅读:57      评论:0      收藏:0      [点我收藏+]

CommonJs模块规范


1、利用require函数加载js
2、exports可以挂一些属性、方法、对象等
3、每一个文件就是一个模块,拥有自己独立的作用域,变量,以及方法等,对其他的模块都不可见。

eg:  

 index.js:
console.log("start require");
var lib = require("./lib.js");
//此处调用的lib是module.exports
console.log("end require", lib);

 

 lib.js:
console.log("hello require");
exports.hello = "World";
exports.add = function (a, b) {
  return a + b;
};

exports.geekbang = { hello: "world" };

module.exports = function minis(a, b) {
  return a - b;
};

//此时调用的exports是上面的exports本身
setTimeout(() => {
  console.log(exports);
}, 2000);

 

 

CommonJS规范规定,每个模块内部,module变量代表当前模块。这个变量是一个对象,它的exports属性(即module.exports)是对外的接口。
加载某个模块,其实是加载该模块的module.exports属性。require方法用于加载模块。

 

CommonJS模块的特点


1、所有代码都运行在模块作用域,不会污染全局作用域。
2、模块可以多次加载,但是只会在第一次加载时运行一次,然后运行结果就被缓存了,以后再加载,就直接读取缓存结果。要想让模块再次运行,必须清除缓存。
3、模块加载的顺序,按照其在代码中出现的顺序。

关于CommonJs规范

原文:https://www.cnblogs.com/wjrelax/p/13253589.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!