蓝狮官网CommonJS模块 和 ECMAScript模块

-cjs只有在node.js环境使用。
-esm在node.js和浏览器环境都可以使用

1、commonjs
在node.js中,每个文件都被视为一个单独的模块。蓝狮注册登陆模块的局部变量是私有的,只有exports出去的变量,才能被外界访问。

默认情况下,node.js会将以下情形视为 cjs模块:

扩展名为.cjs的文件;
扩展名为.js的文件,且离自己最近的package.json文件包含一个顶级字段“type”,其值为“commonjs”;
扩展名为.js的文件,且离自己最近的package.json文件不包含一个顶级字段“type”(建议明确指定 type值,而不是不定义);
扩展名不为.mjs, .cjs, .json, .node, .js的文件,且离自己最近的package.json文件包含一个顶级字段“type”,其值为“module”,但是这些文件通过require引入。
调用require()时,始终使用cjs模块加载器,
require采用同步方式加载,可以在代码的任意位置使用。
由于require()的同步特性,无法使用它加载ECMAScript模块文件。尝试这样做将抛出ERR_REQUIRE_ESM错误。请改用import()。

要获取调用require()时将加载的确切文件名,请使用require.resolve()函数。

1)、对于一个文件,导出的是对象的引用。如果内部的属性变化了,外部也会变化。
2)、对于再次引入同一个文件,如果文件名一模一样,则从缓存里面取
3)、还有种方式,要使模块多次执行代码,请导出函数并调用该函数。

导出一个原始值

//child.js
var counter = 3;
function incCounter() {
counter++;
}
module.exports = {
counter: counter,
incCounter: incCounter,
};

//parent.js
let child = require(‘./child.js’)
console.log(child.counter); // 3
child.incCounter();
console.log(child.counter); // 3没变
导出一个对象

//child.js
var obj = {
counter:3
};
function incCounter() {
obj.counter++;
}
module.exports = {
obj: obj,
incCounter: incCounter,
};
//parent.js
let child = require(‘./child.js’)
console.log(child.obj.counter); // 3
test.incCounter();
console.log(child.obj.counter); // 4 变了
导出一个对象,多个文件,会从缓存里获取

//child.js
var obj = {
counter:3
};
function incCounter() {
obj.counter++;
}
module.exports = {
obj: obj,
incCounter: incCounter,
};
//parent.js
let child = require(‘./child.js’)
let child1 = require(‘./child.js’)
console.log(child.obj.counter); // 3
test.incCounter();
console.log(child.obj.counter); // 4 变了
console.log(child1.obj.counter); // 4 变了
如果require加载的是个文件夹,那么node.js默认会尝试加载 index.js 或者 index.node

动态导入
import() 既支持cjs,又支持 esm

import(‘./lib.js’).then((res)=>{
//res.default
})
2、es module
调用 import()时,始终使用esm模块加载器,

默认情况下,node.js会将以下情形视为 esm 模块:
扩展名为 .mjs 的文件;
扩展名为.js的文件,且离自己最近的package.json文件包含一个顶级字段“type”,其值为“module”;

1)、对于一个文件,导出的是对象的引用。如果内部的属性变化了,外部也会变化。
2)、对于再次引入同一个文件,如果文件名一模一样,则从缓存里面取。如果文件名加了query,则重新加载文件,不会缓存里取
3)、还有种方式,要使模块多次执行代码,请导出函数并调用该函数。

单次导入,导入基本类型

//child.mjs
var counter = 3;
function incCounter() {
counter++;
}
export default {
counter: counter,
incCounter: incCounter,
};

//index.mjs
import child from “./lib.mjs”;
console.log(child.counter); // 3
child.incCounter();
console.log(child.counter); //蓝狮官网 3没变
多次导入,导入引用类型

//child.mjs
var obj = {
counter: 3,
};
function incCounter() {
obj.counter++;
}
export default {
obj: obj,
incCounter: incCounter,
};

//index.mjs
import child from “./lib.mjs”;
import child1 from “./lib.mjs”; //从缓存里面取
console.log(child.obj.counter); // 3
child.incCounter();
console.log(child.obj.counter); // 4变了

console.log(child1.obj.counter); // 4变了,拿的缓存里的

0 Comments
Leave a Reply