当前位置: 首页 > news >正文

【ES6】CommonJS模块和ES6模块

在JavaScript中,模块是一种将功能代码组织成逻辑单元的方式,以便在其他项目中重复使用。有两种主要的模块系统:CommonJS和ES6。

1、CommonJS

在CommonJS中,我们使用require来引入模块,使用module.exports来导出模块。

下面是一个简单的例子:

// math.js
exports.add = function (a, b) {return a + b;
};

然后,在另一个文件中,我们可以使用require来引入这个模块:

// app.js
var math = require('./math');
console.log(math.add(1, 2)); // 输出 3

2、ES6模块

ES6引入了新的模块系统,它支持导入和导出模块。下面是ES6模块的一个例子:

// math.js
export function add(a, b) {return a + b;
};

然后,在另一个文件中,我们可以使用import来引入这个模块:

// app.js
import { add } from './math';
console.log(add(1, 2)); // 输出 3

总的来说,CommonJS和ES6模块的主要区别在于语法、加载方式和只读性。CommonJS是运行时加载,ES6是编译时加载;CommonJS模块输出的是值的拷贝,ES6模块输出的是值的引用;此外,CommonJS模块是可读写的,而ES6模块是只读的

http://www.lryc.cn/news/155732.html

相关文章:

  • 两个线程同步执行:解决乱箭穿心(STL/Windows/Linux)
  • Ubuntu18.04更改镜像源(网易,阿里,清华,中科大,浙大)
  • 字节码和机器码的区别
  • go学习part21 Redis和Go(2)
  • 从0到1学会Git(第二部分):Git的本地操作和管理
  • hive lateral view 实践记录(Array和Map数据类型)
  • 理解 std::thread::join
  • C#循环定时上传数据,失败重传解决方案,数据库标识
  • R语言图形的组合( par(),layout(),par(fig()) )
  • 如何为 Flutter 应用程序创建环境变量
  • 「C++程序设计 (面向对象进阶)」学习笔记・一
  • Leetcode125. 验证回文串
  • 【Yellowbrick】特征可视化分析
  • Android大厂需要刷的(999道)面试题
  • Pycharm中出现ImportError:DLL load failed:找不到指定模块的解决方法
  • Java设计模式:四、行为型模式-08:策略模式
  • ICCOA蓝牙数字车钥匙2.0
  • ArcGIS土地利用程度综合指数分析
  • 服务端请求伪造(SSRF)及漏洞复现
  • v-model和v-bind
  • 详细介绍 弹性盒子(display:flex)
  • Docker使用数据卷挂载进行数据存储与共享
  • [力扣146. LRU 缓存 ](https://leetcode.cn/problems/lru-cache/description/)
  • Mysql存储引擎
  • 算法通关村-----数组实现加法专题问题解析
  • 倒排表的压缩算法
  • Android studio实现自定义圆形进度条 带刻度进度条 计步效果 时速表 水波纹效果
  • 使用【宝塔+docker】在云服务器上部署基于SpringBoot 和 Dubbo RPC 的项目:踩坑记录
  • 【算法与数据结构】617、LeetCode合并二叉树
  • ffmpeg把RTSP流分段录制成MP4,如果能把ffmpeg.exe改成ffmpeg.dll用,那音视频开发的难度直接就降一个维度啊