位置: IT常识 - 正文

CommonJS的理解(commonjs的特点)

编辑:rootadmin
CommonJS的理解 CommonJS是什么?

推荐整理分享CommonJS的理解(commonjs的特点),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:commonjs require,commonjs实现原理,commonjs requirejs,common.js是用来干嘛的,commonjs原理,commonjs原理,commonjs教程,commonjs教程,内容如对您有帮助,希望把文章链接给更多的朋友!

我们主流的前端框架vue/react都是基于node来构建的。在NodeJS出现之前,由于没有特别复杂的页面,前端是没有模块化这个概念的,而NodeJS诞生之后,它使用CommonJS的模块化规范。从此,js模块化开始快速发展。因此,我们知道,commonjs就是一个模块化的规范。目前流行的js模块化规范有CommonJS、AMD、CMD、UMD以及ES6的模块系统。

至于什么是模块化?你能看到这里说明你已经工作有点时间了,这个不需要太多的解释,自行领悟吧。小编文采不行,不知道怎么解释,简单来说,一般来说,一个文件就是一个模块,这个文件内的作用域唯一,可以向外暴露变量,函数等。模块化的出现减少了代码的繁琐,利于代码复用和日后维护等等作用,实在高明!

前面我们说过,NodeJS是使用CommonJS的模块化规范。CommonJS它有四个核心的比较重要的环境变量,分别是modele, exports,require,global.  

modele, exports

如果你有一定的工作经验,那么你一定见过如下代码:

module.exports = {//...............}以及var math = require('XXXX');

module变量代表当前模块。这个变量是一个对象,它的exports属性(即module.exports)是对外的接口,不建议直接使用exports(为什么呢?只能说不熟悉的容易出错,而且使用不方便)。然后我们在其他模块需要引入的地方使用require来引入。

module.exports和exports都能导出,那么究竟这两个之间有什么不同的呢?

exports 导出实际还是使用了module.exports。因为node在内部对exports进行了赋值。

var exports = module.exports;

exports在导出的时候,需要添加属性或者方法,因为它指向的是module.exports,module.exports变量本就是一个对象,实际导出也是导出这个变量。不可以直接给exports赋值一个变量或者函数,这是错误的。。。

exports = '我是错误的导出';//错误的exports = function(){ }; //错误的

正确的是这样:

exports.XXX = '我是错误的导出';//正确的exports.XXX = function(){ }; //正确的CommonJS的理解(commonjs的特点)

看到这里你应该知道为什么不建议使用exports暴露了吧!!

补充下,modules对象都有哪些属性:

module.id,模块的识别符,通常是带有绝对路径的模块文件名;module.filename,模块的文件名,带有绝对路径;module.loaded,返回一个boolean值,表示模块是否已经完成加载;module.parent,返回一个对象,表示调用该模块的模块;module.children,返回一个数组,表示该模块内用到的其他模块;module.exports,表示模块对外输出的值; require

require就是加载模块的。所有加载的模块都会缓存保存在require.cache中。

使用require加载模块的时候,必须加 ./ 路径,不加的话只会去node_modules文件找。

// 引用自定义的模块时,参数包含路径,可省略.jsvar math = require('./math');// 引用核心模块时,不需要带路径var http = require('http');

这里了解下require使用时候的内部处理流程:

1.在执行到require语句的时候,先检查是否存在这个模块的缓存;

2.如果没找到缓存,那么就会创建一个新的module实例,并且缓存下exports导出的值。如果没发现exports的模块那么会报错;

3.如果缓存存在的话,执行module.load()这个方法,去加载这个模块,读取文件内容后,使用module.compile()执行文件代码;

4.如果解析的过程中,出现异常,就从缓存中删除这个模块;

5.如果没有出现异常,最后返回这个模块的module.exports;

global

global对象是nodejs的全局对象,上边挂在了一些最基本的全局方法。

CommonJS模块的缓存

从require引入我们使用了缓存。当我们第一次加载模块的时候,node会加载他并且缓存下来,之后使用的时候就会直接从缓存内读取module.exports的值。缓存是根据绝对路径识别模块的,如果同样的模块名,但是保存在不同的路径,require命令还是会重新加载该模块。所以加载模块只会在第一次,后面如果需要重新加载可以通过清除缓存。

CommonJS的缺点

首先我们需要了解CommonJS的加载方式是同步加载的,这意味着只有前面执行完成才会继续执行。因为同步就会存在一个问题,加载的速度受到影响。Node.js主要用于服务器编程,模块文件一般都已经存在于本地硬盘,所以加载起来比较快,不用考虑非同步加载的方式,所以CommonJS规范比较适用。但是,如果是浏览器环境,要从服务器端加载模块,这时就必须采用非同步模式,因此浏览器端一般采用AMD规范。

本文链接地址:https://www.jiuchutong.com/zhishi/299442.html 转载请保留说明!

上一篇:文心一言 VS ChatGPT,国产大模型和国外的差距有多大?(文心一言 VS ChatGPT)

下一篇:终于,OpenAI开放ChatGPT API,成本直降90%,百万token才2美元(open开放的意思吗)

  • 出口应退税额如何计算
  • 用友T6自定结转怎样设置
  • 未投入使用的固体废物
  • 发票超过认证期限可以红冲重开吗
  • 金银首饰在哪个平台买比较好
  • 企业所得税汇算清缴申报表
  • etc设备有区别吗
  • 冲销暂估入库
  • 企业的房产税节税有哪些方案?
  • 免税货物开成含税率的怎么报税?
  • 理财产品分红怎么入账
  • 税务顾问费怎么做账务处理?
  • 增值税进项大于销项,要全部认证吗
  • 个税申报系统中年收入不超6万元的确认错了怎么改
  • 事业单位的房租上缴国库吗
  • 增值税留底税怎么计算
  • 简并税率政策是什么?简并税率政策要点如何解读?
  • 关联申报不报有影响吗
  • 防暑降温列支什么费用
  • 收到劳务外包发票计入什么科目
  • 保险付款后几天给发票保单
  • 可以在企业所得税税前扣除的税金有
  • 利润分配会计处理时间
  • 专用发票已认证怎么退回
  • 费用跨年的分录怎么做
  • 税盘维护费的账务处理
  • 安装下载应用
  • uniqpp
  • 没有了睡眠功能
  • 对公帐户定期存款利率
  • 开发产品结转到哪个科目
  • pniopcac.exe是什么
  • 高新技术企业研发费加计扣除政策
  • 新的担保法是怎么规定的
  • 企业废业什么意思
  • 如何用php制作网页
  • npm install 的 --save 选项是什么?
  • Win11 KB5025239 / KB5025224 累积更新今日发布
  • 怎么做一个简单的机器
  • 支付银行手续费等直接收费金融服务
  • 小规模申报增值税减免税申报明细表
  • 畜牧业科技公司
  • 人力资源公司的税率是多少
  • 申请电子发票需要什么条件
  • sql默认路径在哪里
  • 房屋维修基金是谁交
  • 公司购买不动产契税税率
  • 车船税是什么样子的?
  • 其他权益工具账面价值
  • 保理业务的内容有哪些
  • 退税政策调整
  • 小规模纳税人销售货物税率是多少
  • 内部使用的收据可以做原始凭证吗
  • 快递费用在线查询
  • 暂估入库结转成本
  • 已经计提的坏账收回了怎么做
  • 目标考核奖金做什么科目
  • 内帐与外帐的哪个更好
  • ubuntu20 vnc
  • kvm虚拟机paused
  • winxp系统开机蓝屏
  • ubuntu浏览网页
  • win7共享文件权限设置
  • linux压缩.z
  • WindowsPE与WindowsRE有什么区别
  • imessage如何群发
  • 无法打开文件exe
  • cocos2d官网
  • python标准库很庞大,它可以帮助处理各种工作,包括
  • node:js
  • js复制数组的方法
  • 基于javascript的毕业设计选题
  • Python中time模块中的方法
  • 基于python的聊天软件
  • python爬虫类
  • python3.5升级
  • 如何查发票是否作废
  • 贵州电子税务局app下载
  • 延安市地方税务局电话
  • 省税务局属于什么级别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设