JS 模块化- 04 CMD 规范与 Sea JS

1 CMD 规范介绍

CMDCommon Module Definition, 通用模块定义。与 AMD 规范类似,也是用于浏览器端,异步加载模块,一个文件就是一个模块,当模块使用时才会加载执行。其语法与 AMD 规范很类似。

1.1 定义模块

定义模块使用 define 函数:

define(factory)

define 函数接收的参数 factory 可以是一个对象、字符串或函数。如:

define({ 'str': 'Hello World' })

define('Hello world')

factory 为函数时,这个函数就是当前这个模块的构造函数,该函数接收三个参数:

define(function(require, exports, module) {

})

这三个参数的意义如下:

- require:函数,可以通过该函数加载其他模块
- exports:对象,用于向外部提供接口,即可以通过该对象导出对象、属性或函数,将本模块内部的变量、函数等暴露给其他模块使用
- module:对象,存储当前模块相关的属性和函数

1.2 加载模块

CMD 规范中,所有的 JS 都是在模块中,入口模块 —— 主模块也是一个模块,使用模块工厂函数的 require 函数加载其他模块。

define(function(require, exports, module) {
    const m = require('./m1')
  console.log(m1)
})

异步加载模块:

define(function(require, exports, module) {
    require.async('./m1', function (m3) {
    console.log(m1)
  })
})

2 Sea.js

Sea.jsCMD 规范的浏览器端实现。

2.1 使用准备

从 github 上下载 sea.js,创建如下目录文件结构:

04_CMD/
|- lib/
    |- sea.js
|- modules/
    |- module1.js
    |- module2.js
    |- module3.js
|- index.js
|- index.html

modules 目录存放三个模块, index.js 为入口(主模块)。

2.2 实现三个模块

module1.js 导出 sum 函数:

define(function (require, exports, module) {

  console.log('in module1.')

  function sum(num1, num2) {
    console.log('module1 sum function.', num1, num2)
    return num1 + num2
  }

  exports.sum = sum
})

module2.js 定义并导出一个内部变量 str 和函数 calculate ,calculate 函数调用 module1sum 函数。

define(function (require, exports, module) {

  console.log('in module2')

  const str = '优雅哥测试'

  function calculate (n1, n2) {
    const m1 = require('./module1')
    return m1.sum(n1, n2)
  }

  exports.obj = {
    str,
    calculate
  }
})

在 module2.js 的 calculate 函数中加载 module1,咱在后面会多次调用 calculate 函数,测试模块是否会重复加载。

module3.js 用于测试异步加载,只定义并通过 return 导出一个 demo 函数:

define(function (require, exports, module) {

  console.log('in module3')

  function demo() {
    console.log('demo function')
  }

  return {
    demo
  }
})

2.3 实现主模块

index.js 中,异步加载 module3,同步加载 module2,并多次调用 module2 中导出的 calculate 函数:

define(function (require) {

  console.log('in index')

  require.async('./modules/module3', function (m3) {
    console.log('异步加载 module3')
    m3.demo()
  })

  const m2 = require('./modules/module2')
  console.log(m2.obj.str)

  console.log(m2.obj.calculate(10, 20))
  console.log(m2.obj.calculate(100, 200))
  console.log(m2.obj.calculate(1000, 3000))
})

2.4 实现入口页面

index.html 中首先通过 script 标签引入 sea.js,然后加载主模块:


  seajs.use('./index.js')

2.5 测试运行

在浏览器中运行 index.html,在浏览器控制台中输出如下:

JS 模块化- 04 CMD 规范与 Sea JS

从控制台输出可以看出:

  1. module3 由于是异步加载,所以输出位置与代码位置不同;
  2. 导出模块处理使用 exports.xxx,也可以使用 return
  3. 虽然多次调用了 calculate 函数, calculate 函数中加载 module1,但 module1 不会被加载多次,加载后会被缓存起来。

3 总结

CMD 规范的语法:

// 定义模块
define(function(require, exports, module) {
    // 同步加载模块
    const m1 = require('../xxx')

    // 异步加载模块
    require.async('../xxx', function (m2) {
    })

    // 使用 exports 导出模块
    exports.xxx = xxx

    //也可以使用 return 导出模块
    // return xxx
})

感谢你阅读本文,如果本文给了你一点点帮助或者启发,还请三连支持一下,点赞、关注、收藏,作者会持续与大家分享更多干货

Original: https://www.cnblogs.com/youyacoder/p/16735039.html
Author: 程序员优雅哥(公/同)
Title: JS 模块化- 04 CMD 规范与 Sea JS

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/801820/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 【pytest学习总结1】基础介绍

    1.pytest的特点: pytest是一个非常成熟的全功能的Python测试框架,主要有以下几个特点:简单灵活,容易上手;支持参数化;能够支持简单的单元测试和复杂的功能测试,还可…

    Python 2023年9月11日
    042
  • 动态规划——线性dp

    基于数字三角形问题扩展 参考闫氏 d p 分析法 参考闫氏dp分析法参考闫氏d p 分析法 方格取数 f [ i 1 ] [ j 1 ] [ i 2 ] [ j 2 ] 表示( 1…

    Python 2023年10月1日
    046
  • python怎么用pandas查找指定字符串_【Python数据分析】pandas针对字符串操作

    1.字符串调用属性:str 通过str属性操作,会自动排除丢失NaN值 import numpy as np import pandas as pd s = pd.Series([…

    Python 2023年8月18日
    060
  • 使用pyqt5的日期控件做一个小日历方便查看

    日历的制作比较简单,因为pyqt5已经自带了相关的日期控件,只需要明白如何调用再加上比较个性化的功能,这个日历的小控件就制作完成了。 【阅读全文】 日历实现代码不多,需要可以直接执…

    Python 2023年5月24日
    069
  • Abp vNext 切换MySql数据库

    Abp vNext是Abp的下一代版本,目前还在经一步完善,代码已经全部重写了,好的东西保留了下来,去除了很多笨重的东西,从官宣来看,Abp vNext主要是为了以后微服务架构而诞…

    Python 2023年6月12日
    048
  • python—数据分析(二)

    Series和DataFrame中数据的基本功能: reindex方法是创建一个新对象,其数据对Series和DataFrame的新索引,它们的主要区别在DataFrame可以对i…

    Python 2023年8月8日
    055
  • 开源数字基础设施 项目 — Speckle

    Speckle是用于 3D 设计的任何东西的开源数字基础设施。处理软件孤岛、实时协作、数据管理、版本控制和自动化之间的互操作性。致力于构建一个开源代码平台,让建筑设计工作者能够协作…

    Python 2023年10月18日
    061
  • 你真的会python中的for循环吗

    Original: https://www.cnblogs.com/123456feng/p/16152818.htmlAuthor: 蚂蚁ailingTitle: 你真的会pyt…

    Python 2023年5月24日
    048
  • MacBook M1安装Numpy,Pandas,Matplotlib

    MacBook M1安装Numpy,Pandas,Matplotlib * – + 我的环境 + 安装遇到的问题 + 常见的Numpy、Pandas安装方法总结 + 简…

    Python 2023年9月2日
    034
  • pytest中allure特性

    ; 一、@allure.step allure报告最重要的一点是,它允许对每个测试用例进行非常详细的步骤说明通过 @allure.step() 装饰器,可以让测试用例在allure…

    Python 2023年9月12日
    050
  • 【opencv之python版】图像的读取、显示、保存、像素遍历以及结合matplotlib使用

    文章目录 1. 图像的表示 2. 图像读取、显示与保存 3. 简单使用 * 3.1 读取图像大小 3.2 绘制基本图形 3.3 图像的元素遍历 4. 结合Matplotlib显示图…

    Python 2023年9月3日
    045
  • pytest-配置文件

    pytest.ini是pytest的主配置文件,可以改变pytest的默认行为 对于一些常用的命令行参数,比如-v,-s,经常使用,但是又不想重复输入,可以在pytest.ini文…

    Python 2023年9月10日
    070
  • 1小时学会Git玩转GitHub

    版权声明:原创不易,本文禁止抄袭、转载,侵权必究! 本次教程建议一边阅读一边用电脑实操 目录 一、了解Git和Github * – + 1.1 什么是Git + 1.2…

    Python 2023年6月3日
    072
  • Net5 WorkService 继承 Quarzt 以及 Net5处理文件上传

    Net5 版本以Core为底层非framework框架的windowservice 服务。 在VS里叫WorkService 可以以CMD方式运行也可以以Windowservice…

    Python 2023年6月6日
    064
  • [pytorch学习笔记] 2. tensor 张量

    张量初始化 1.张量可以直接从数据中创建。 数据类型是自动推断的。 2.张量通过numpy 中的数组进行初始化。 3.通过别的张量进行初始化 4.使用随机数或常数初始化: Tens…

    Python 2023年8月27日
    050
  • Python poetry的使用

    poetry是一个Python虚拟环境和依赖管理的工具,其官网文档: https://python-poetry.org/docs 1.使用pip安装poetry pip inst…

    Python 2023年8月28日
    044
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球