前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript模块化-CommonJS、AMD、CMD、UMD、ES6

JavaScript模块化-CommonJS、AMD、CMD、UMD、ES6

作者头像
胡哥有话说
发布2020-04-14 17:35:57
8220
发布2020-04-14 17:35:57
举报
文章被收录于专栏:胡哥有话说胡哥有话说

前言:模块化开发需求

在JS早期,使用script标签引入JS,会造成以下问题:

  1. 加载的时候阻塞网页渲染,引入JS越多,阻塞时间越长。
  2. 容易污染全局变量。
  3. js文件存在依赖关系,加载必须有顺序。项目较大时,依赖会错综复杂。
  4. 引入的JS文件过多,不美观,且不易于管理。

一、CommonJS规范

CommonJS Modules/1.0规范,服务器端规范。

Node.js推广使用。该规范的核心是:允许模块使用require方法来同步加载所依赖的其他模块,然后通过exports或module.exports导出需要暴露的接口。

特点:

1.一个模块是一个文件

2.使用module.exports或exports导出模块

代码语言:javascript
复制
 // module.js
 exports.add = (a, b) => a+b

 module.exports = {
   add: (a, b) => a + b
 }

使用require加载模块

代码语言:javascript
复制
 a. require命令第一次加载模块时,执行整个脚本,在内存中生成对象
 b. 多次执行require命令再次加载该模块时,不会再执行该脚本,直接从缓存中取值
 c. CommonJS加载模块是同步加载模块
Tips:
  1. 为什么CommonJS规范不适合作为浏览器的规范 由于CommonJS是同步加模块,在服务端加载模块时都是从本地硬盘中加载,读取速度很快。但是在浏览器端加载模块时,需要请求服务器端,涉及网速、代理的问题,一旦等待时间过长,浏览器会处于“假死”状态。

二、ADM规范

AMD(Asynchronous Module Definition)异步模块定义,客户端规范。采用异步方式加载模块,模块加载不影响它后面语句的代执行。

AMD是require.js在推广使用过程中对模块定义规范化的产物。

在使用时,需引入require.js

特点

1.使用define()定义模块

代码语言:javascript
复制
 /**
  * @param id 模块名称,如果为空,模块的名字默认为模块加载器请求的指定脚本名
  * @param dependencies 模块依赖
  * @param factory 工场函数,模块初始化执行的函数或对象
  */
 define(id? dependencies? factory)

2.使用require加载模块 require([module], callback) AMD是依赖前置模块

三、CMD规范

CMD(Common Module Definition)通用模块定义,异步加载模块。

CMD是sea.js在推广过程中对模块定义的规范化产物。

在使用时,需引入sea.js

特点:

1.使用define()定义模块,使用require()加载模块

代码语言:javascript
复制
 define(function (require, exports, module) {
 let a = require('a')
 let b = require('b')
     exports.eat = a.eat
     exports.run = b.run
 })

CMD模块加载是推崇就近依赖的,需要到某个模块时再进行require加载

2.使用seajs.use加载使用模块 seajs.use(id, callback?)

四、UMD规范

UMD(Universal Module Definition)通用模块定义,为了兼容AMD、CMD和无模块化开发规范

代码语言:javascript
复制
/**
 * UMD-Universal Module Definition 通用模块定义
 * */
 (function (root, factory) {
     // 判断是否是AMD/CMD
     if (typeof define === 'function') {
         define([], factory)
     } else if (typeof exports === 'object') {
         // Node CommonJS规范
         module.exports = factory()
     } else {
         // 浏览器环境
         root.someAttr = factory
     }
 })(this, function () {
     let add = function (a, b) {
         return a + b
     }
     return {
         add,
         module: 'UMD'
     }
 })

五、ES6模块

ES6通过imort和export实现模块的输入与输出,import命令用于输入其他模块提供的功能,export命令用于规定模块对外的接口。

特点:

使用export导出模块

代码语言:javascript
复制
 // test.js
 export let module = 'ES6 Module'
 export let hello = function () {}
 let demo = function () {}
 // 默认导出
 export default demo

使用import导入模块

代码语言:javascript
复制
 // 导入默认模块
 import demo from './test.js'

 // 导入指定模块
 import { hello, module } from './test'

 // 导入指定模块,并重命名
 import { hello as hi, module } from './test.js'

 // 导入全部模块,并重命名
 import * as test from './test.js'
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-04-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 胡哥有话说 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言:模块化开发需求
  • 一、CommonJS规范
    • 特点:
      • Tips:
      • 二、ADM规范
        • 特点
        • 三、CMD规范
        • 四、UMD规范
        • 五、ES6模块
        相关产品与服务
        命令行工具
        腾讯云命令行工具 TCCLI 是管理腾讯云资源的统一工具。使用腾讯云命令行工具,您可以快速调用腾讯云 API 来管理您的腾讯云资源。此外,您还可以基于腾讯云的命令行工具来做自动化和脚本处理,以更多样的方式进行组合和重用。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档