node.js 第四天 模块化CommonJs
创始人
2024-05-29 10:59:33
0

文章目录

      • CommonJS
        • exports
        • module.exports
      • ES模块
        • export
        • export default
      • 核心 模块
          • process

CommonJS

通过exports暴露出去,require获取暴露的内容

exports

exports一个一个暴露出去
文件01.js

exports.a='孙悟空';
exports.b ={name:'白骨精'}
exports.c =function fn(){console.log("hello")
} 

文件02.js
require中的路径必须是 ./ 或 ../ 开头,里边的.js扩展名可以省略,如果省略了扩展名,nodejs可以为我们补全,优先找js文件,找不到找json文件

const m =require('./01.js')
console.log(m)
m.c()

module.exports

通过 module.exports同事导出多个值

module.exports ={a:'孙悟空',b:[1,2,30],c:()=>{console.log('xixi')}
}
const m =require('./01.js')
console.log(m)    //孙悟空
m.c()      //xixi

默认情况下,Node.js会将以下内容视为CommonJS模块:

  1. 使用.cjs为扩展名的文件
  2. 当前的package.json的type属性为commonjs时,扩展名为.js的文件
  3. 当前的package.json不包含type属性时,扩展名为.js的文件
    文件夹作为模块

模块的包装
每一个CommonJS模块在执行时,外层都会被套上一个函数:

(function(exports, require, module, __filename, __dirname) {
// 模块代码会被放到这里
});

所以我们之所以能在CommonJS模块中使用exports、require并不是因为它们是全局变量。它们实际上以参数(实参)的形式传递进模块的。

exports,用来设置模块向外部暴露的内容

require,用来引入模块的方法

module,当前模块的引用

__filename,模块的路径

__dirname,模块所在目录的路径,即当前文件所在的文件夹路径

ES模块

export

默认情况下,node只的模块化标准是 CommonJS
要想使用ES的模块化,可以使用以下两种方法

  1. 使用 .mjs作为扩展名
  2. 在package.json中设置 type:"module" , 当前项目下所有的js文件都变成ES模块, type 默认是 CommonJS

新建一个03.mjs 这里扩展是 .mjs,如果不是ES模块就会报错

export let a =10;
export const b={name:"孙悟空"}

新建一个04.mjs

import {a as A ,  b} from './03.mjs'   # as 换个别名,这里默认的名字不能乱写,与前面暴露的名字要一致
console.log(A,b)

export default

一个模块只能有一个默认导出,默认导出的命名可以随意

export let a =10;
export default function sum(a,b){return a+b
}

默认导出可以随意命名

import x ,{a} from './03.mjs'
console.log(x,a)    

默认导出的是值,不能是语句

export default let a =10;   错误let a= 10;
export default a   对的

导入的内容都是常量导入的内容跟前面定义的没关系,只要是导入的都是常量,常量并不影响对象的修改

export let a =10;
export const b={name:"孙悟空"}
import {a,b} from './03.mjs'
console.log(a)
a =20   #报错  这里不能给常量修改值b.name ="ddd"
console.log(b)   #对的  

ES模块化在浏览器中可以使用,但是通常我们不会使用,因为要考虑兼容性的问题,通常结合打包工具使用

核心 模块

window是浏览器的宿主对象,node没有
global是node的全局对象 ,作用类似于window
在ES模块下,都可以共 globalThis

process

表示当前的node进程
通过该对象可以获取进程的信息,或者对进程做各种操作
process.exit([code]) 结束进程
process.nextTick(callback[, …args]) 向tick任务队列中添加任务
process.nextTick 跟queueMicrotask 都是微任务队列中添加任务

queueMicrotask(()=>{console.log(1)
})
process.nextTick(()=>{console.log(2)
})//  2   1

调用栈 -》tick队列-》微任务队列-》宏任务队列

所以queueMicrotask 在tick后面执行,不需要了解

相关内容

热门资讯

铜陵有色已回购2951万股 金... 7月1日,铜陵有色(000630)发布公告,截至2025年6月30日,公司已回购2951万股,占总股...
国家发改委:国内汽、柴油价格每... 据国家发改委,根据近期国际市场油价变化情况,按照现行成品油价格形成机制,自2025年7月1日24时起...
募资用途初步披露,亿纬锂能递表... 6月30日晚间,亿纬锂能(维权)公告称,公司已于当日向香港联交所递交了发行境外上市外资股(H股)并在...
国内汽柴油价格7月1日24时上... 全国平均来看,92号汽油、95号汽油和0号柴油每升上调0.18元、0.19元和0.19元。 ...
领益智造累计回购3823万股 ... 7月1日,领益智造(002600)发布公告,截至2025年6月30日,累计回购3823万股,占总股本...
最高奖励2000元!福州公开征... 夏木阴阴,水韵悠长。作为一座有着2200多年建城史的文化名城,福州自建城以来就与水密不可分。千百年来...
欧洲银行股上半年历史性飞跃:斯... 欧洲银行业上半年交出了一份令市场瞩目的成绩单。斯托克600银行指数以29%的涨幅创下1997年以来最...
1—5月湖南规模工业企业效益延...   长沙晚报掌上长沙7月1日讯(全媒体记者 周丛笑 通讯员 杨雪)1日,省统计局公布数据:1—5月,...
龙虎榜|山河药辅涨停,开源证券... 7月1日,山河药辅涨停,日振幅值达13.61%,日换手率达32.06%,收盘价14.72元,成交额8...
钻石的量子革命:这颗“原子级眼...   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会! 在上一篇文章中,我们...