前端模块化CommonJS、AMD、CMD、ES6

在前端开发中,模块化是一种重要的代码组织方式,它有助于将复杂的代码拆分成可管理的小块,提高代码的可维护性和可重用性。CommonJS、AMD(异步模块定义)和CMD(通用模块定义)是三种不同的模块规范,它们在定义模块、加载模块以及依赖管理等方面存在差异,并适用于不同的场景。

CommonJS、AMD、CMD 

一、CommonJS

1. 定义与特点

  • CommonJS是服务器端JavaScript模块化的规范,Node.js是这种规范的实现
  • 一个单独的文件就是一个模块,模块通过module.exports导出接口,通过require()导入其他模块。
  • 加载模块是同步的,即只有加载完成才能执行后面的操作

2. 适用场景

  • 主要用于服务器端JavaScript的模块化开发,如Node.js环境。
  • 适用于模块之间依赖关系明确,且对加载速度要求不高的场景。

二、AMD

1. 定义与特点

  • AMD是RequireJS在推广过程中对模块定义的规范化产出,主要用于浏览器端
  • 使用define()函数定义模块,可以异步加载模块,不会阻塞后续代码的执行。
  • 允许指定回调函数,当所有依赖的模块都加载完成后,会执行这个回调函数

2. 适用场景

  • 适用于浏览器端的大型Web应用,特别是那些需要按需加载模块以减少初始加载时间的场景。
  • 当模块之间的依赖关系复杂,且需要优化加载性能时,AMD是一个不错的选择。

三、CMD

1. 定义与特点

  • CMD是SeaJS在推广过程中对模块定义的规范化产出,也主要用于浏览器端。
  • 与AMD类似,CMD也使用define()函数定义模块,但CMD推崇依赖就近和延迟执行(懒加载)。
  • 只有在真正需要某个模块时,才会去加载和执行它

2. 适用场景

  • 适用于对加载性能有较高要求的浏览器端应用。
  • 当模块数量较多,且大多数模块只在特定条件下才会被使用时,CMD的懒加载特性可以显著减少不必要的加载时间。
CommonJSAMDCMD
定义服务器端JavaScript模块规范浏览器端Javascript模块规范浏览器端JavaScript模块规范
实现Node.jsRequireJSSeaJS
加载方式同步加载异步加载延迟加载(懒加载)
适用场景服务端开发浏览器端大型Web应用,需要优化加载性能浏览器端应用,模块数量多且大多只在特定条件下使用
特点模块定义简单直接依赖前置,异步加载依赖就近,延迟执行

综上所述,CommonJS、AMD和CMD各有其特点和适用场景。在选择模块规范时,需要根据项目的具体需求和目标来决定。例如,对于服务器端JavaScript开发,通常会选择CommonJS;而对于浏览器端的大型Web应用,则可能会考虑使用AMD或CMD来优化加载性能和减少初始加载时间。

ES6(ECMAScript 6)中的模块化语法主要通过importexport两个关键字来实现,这一机制极大地增强了JavaScript代码的组织性、可维护性和可重用性。以下是对ES6模块化语法的详细解析及其优势:

ES6模块化语法

export

export关键字用于规定模块的对外接口,即定义哪些变量、函数、类等可以被其他模块通过import语句导入。其基本用法包括:

直接导出:在模块文件内部,使用export关键字直接导出变量、函数、类等。例如:

export const PI = 3.14;  
export function add(x, y) {  return x + y;  
}

统一导出:使用花括号{}将多个导出项组织在一起。例如: 

const PI = 3.14;  
function add(x, y) {  return x + y;  
}  
export { PI, add };

 默认导出:每个模块只能有一个默认导出,使用export default关键字。默认导出的内容在导入时可以使用任意名称。例如:

function createCircle(radius) {  // ...  
}  
export default createCircle;
import

import关键字用于从其他模块导入功能,即获取其他模块通过export导出的变量、函数、类等。其基本用法包括:

命名导入使用花括号{}明确指定要导入的导出项及其名称。例如

import { PI, add } from './math.js';

 默认导入:使用任意名称导入模块的默认导出项。例如:

import Circle from './circle.js'

整体导入:使用* as语法导入模块的所有导出项,并为它们指定一个命名空间。例如:

import * as math from './math.js';  
console.log(math.PI);  
console.log(math.add(1, 2));

ES6模块化的优势

  1. 显式依赖:ES6模块通过importexport显式地声明了模块之间的依赖关系,这有助于工具进行静态分析,优化加载策略。

  2. 编译时加载:与CommonJS等运行时加载的模块系统不同,ES6模块支持编译时加载这意味着在代码执行之前,模块之间的依赖关系已经确定,有助于提升代码的执行效率

  3. 更好的封装:ES6模块将每个文件视为一个独立的模块,模块内部的所有变量和函数默认都是私有的,只有通过export显式导出的内容才能被其他模块访问,这有助于实现更好的封装和代码隐藏。

  4. 更简洁的语法importexport的语法简洁明了,易于理解和使用,相比CommonJS的requiremodule.exports更加直观。

  5. 支持静态分析:由于ES6模块是静态的,工具可以在不执行代码的情况下分析模块的依赖关系,这有助于实现诸如代码分割、懒加载等优化策略

  6. 支持Tree Shaking:在打包工具(如Webpack、Rollup等)的支持下,ES6模块可以实现Tree Shaking,即自动移除未被引用的代码,从而减小最终打包文件的大小

综上所述,ES6模块化语法通过importexport提供了强大的模块定义和导入功能,不仅提升了代码的组织性和可维护性,还带来了编译时加载、更好的封装、更简洁的语法以及支持静态分析和Tree Shaking等优势。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/385403.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1、hadoop环境搭建

1、环境配置 ip(/etc/sysconfig/network-scripts) # 网卡1 DEVICEeht0 TYPEEthernet ONBOOTyes NM_CONTROLLEDyes BOOTPROTOstatic IPADDR192.168.59.11 GATEWAY192.168.59.1 NETMASK 255.255.255.0 # 网卡2 DEVICEeht0 TYPEEthernet ONBOOTyes NM_CONTROLLEDyes BOOTPROTOdh…

【React1】React概述、基本使用、脚手架、JSX、组件

文章目录 1. React基础1.1 React 概述1.1.1 什么是React1.1.2 React 的特点声明式基于组件学习一次,随处使用1.2 React 的基本使用1.2.1 React的安装1.2.2 React的使用1.2.3 React常用方法说明React.createElement()ReactDOM.render()1.3 React 脚手架的使用1.3.1 React 脚手架…

基于tkinter的学生信息管理系统之登录界面和主界面菜单设计

目录 一、tkinter的介绍 二、登陆界面的设计 1、登陆界面完整代码 2、部分代码讲解 3、登录的数据模型设计 4、效果展示 三、学生主界面菜单设计 1、学生主界面菜单设计完整代码 2、 部分代码讲解 3、效果展示 四、数据库的模型设计 欢迎大家进来学习和支持&#xff01…

从食堂采购系统源码到成品:打造供应链采购管理平台实战详解

本篇文章,笔者将详细介绍如何从食堂采购系统的源码开始,逐步打造一个完备的供应链采购管理平台,帮助企业实现采购流程的智能化和高效化。 一、需求分析与规划 一般来说,食堂采购系统需要具备以下基本功能: 1.供应商…

第15周 Zookeeper分布式锁与变种多级缓存

1. Zookeeper介绍 1.1 介绍 1.2 应用场景简介 1.3 zookeeper工作原理 1.4 zookeeper特点

AI的欺骗游戏:揭示多模态大型语言模型的易受骗性

人工智能咨询培训老师叶梓 转载标明出处 多模态大型语言模型(MLLMs)在处理包含欺骗性信息的提示时容易生成幻觉式响应。尤其是在生成长响应时,仍然是一个未被充分研究的问题。来自 Apple 公司的研究团队提出了MAD-Bench,一个包含8…

DLMS/COSEM中公开密钥算法的使用_椭圆曲线加密法

1.概述 椭圆曲线密码涉及有限域上的椭圆曲线上的算术运算。椭圆曲线可以定义在任何数字域上(实数、整数、复数),但在密码学中,椭圆曲线最常用于有限素数域。 素数域上的椭圆曲线由一组实数(x, y)组成,满足以下等式: 方程的所有解的集合构成…

内网漏扫工具fscan

一、介绍: fscan是一款内网综合扫描工具,方便一键自动化、全方位漏扫扫描。支持主机存活探测、端口扫描、常见服务的爆破、ms17010、redis批量写公钥、计划任务反弹shell、读取win网卡信息、web指纹识别、web漏洞扫描、netbios探测、域控识别等功能。 …

Pytorch使用教学8-张量的科学运算

在介绍完PyTorch中的广播运算后,继续为大家介绍PyTorch的内置数学运算: 首先对内置函数有一个功能印象,知道它的存在,使用时再查具体怎么用其次,我还会介绍PyTorch科学运算的注意事项与一些实用小技巧 1 基本数学运算…

【高中数学/反比例函数/增减区间】从熟悉的y=1/x到陌生的y=x/(1-x)的演变

【题目】 求yx/(1-x)的递增区间? 【解答】 此问题只要能画出yx/(1-x)的大致图像就能解答,首先我们需要将分式化简: yx/(1-x)(x-11)/(1-x)-11/(1-x) 从新的函数式中我们可以判断这也是一个反比例函数,可以从y1/x演变过来。 下…

vue2和el-input无法修改和写入,并且不报错

文章目录 一. 业务场景描述二. 原因分析三.解决方案3.1 方案一 原生标签(不建议)3.2 方案二 父子传递(不建议)3.3 方案三 vuex,pinia 状态传值(不建议)3.4 方案四 vue初始化属性 (建…

PyCharm2024 专业版激活设置中文

PyCharm2024 专业版激活设置中文 官网下载最新版:https://www.jetbrains.com/zh-cn/pycharm/download 「hack-jet激活idea家族.zip」链接:https://pan.quark.cn/s/4929a884d8fe 激活步骤: 官网下载安装PyCharm ;测试使用的202…

javaEE-01-tomcat

文章目录 javaWebTomcat启动 Tomcat 服务器测试服务器是否成功停止tomcat服务器修改服务器的端口号 Idea整合tomcat服务器 javaWeb 所有通过 Java 语言编写可以通过浏览器访问的程序的总称,是基于请求和响应来开发的。 请求: 客户端给服务器发送数据(Request)响应: 服务器给客…

[极客大挑战 2019]BabySQL1

这是上一个SQL注入的升级版,首先打开靶机 有了上次的经验,我们直接联合查询:?usernameaaaunion select null,null,null#&password1234 看报错信息,null,null,null#有错误,猜测select被过滤…

spring常用注解有哪些

Spring框架使用了大量的注解来简化配置和开发,以下是一些常用的Spring注解: 1.Component:通用的构造型注解,用于标记一个类作为Spring管理的组件,通常用于自定义组件。 2.Autowired:用于自动装配Bean&#…

OCCT使用指南:Foundation Classes

1、介绍 本手册解释了如何使用Open CASCADE Technology (OCCT) Foundation Classes。它提供了关于基础类的基础文档。有关基础类及其应用的高级信息,请参阅我们的电子学习和培训产品。 基础类提供各种通用服务,如自动动态内存管理(通过句柄操…

RT-Thread debug 卡死在Stm32_putc问题分析解决

问题和解决方法 找了块开发板玩RT-Thread,一顿骚操作之后,发现debug就卡死在Stm32_putc(不稳定,反复重新上下电,重来有时候卡死有时候不卡死),卡死情况如下图: 先最后的解决方法:取消调默认的内…

MySQL数据库-备份恢复

一、MySQL日志管理 1.为什么需要日志 用于排错用来做数据分析了解程序的运行情况,了解MySQL的性能 2.日志作用 在数据库保存数据时,有时候不可避免会出现数据丢失或者被破坏,这样情况下,就必须保证数据的安全性和完整性&#…

《javaEE篇》--阻塞队列详解

阻塞队列 阻塞队列概述 阻塞队列也是一种队列,和普通队列一样遵循先进先出的原则,但是阻塞队列相较于普通队列多了两项功能阻塞添加和阻塞移除,使得阻塞队列成为一种线程安全的数据结构 阻塞添加:当队列满的时候继续入队就会阻…

css大屏设置中间元素四周渐变透明效果

css大屏设置中间元素四周渐变透明效果 四周透明效果: // 设置蒙版上下左右渐变显示mask-image: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 10%, rgba(0, 0, 0, 1) 90%, rgba(0, 0, 0, 0) 100%),linear-gradient(to bottom, rgba(0, 0, 0…