当前位置:首页 > 日记 > 正文

如何正确理解javascript的模块化

如何正确理解javascript的模块化

模块化在项目中十分的重要,一个复杂的项目肯定有很多相似的功能模块,如果每次都需要重新编写模块肯定既费时又耗力。但是引用别人编写模块的前提是要有统一的“打开姿势”,如果每个人有各自的写法,那么肯定会乱套,下面介绍几种JS的模块化的规范。

一:模块化进程一:script标签

这是最原始的 JavaScript 文件加载方式,如果把每一个文件看做是一个模块,那么他们的接口通常是暴露在全局作用域下,也就是定义在 window 对象中,不同模块的接口调用都是一个作用域中,一些复杂的框架,会使用命名空间的概念来组织这些模块的接口。

缺点:

1、污染全局作用域

2、开发人员必须主观解决模块和代码库的依赖关系

3、文件只能按照script标签的书写顺序进行加载

4、在大型项目中各种资源难以管理,长期积累的问题导致代码库混乱不堪

二:模块化进程二:CommonJS规范

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

require("module");require("../file.js");exports.doStuff = function(){};module.exports = someValue;

优点:

1、简单并容易使用

2、服务器端模块便于重用

缺点:

1、同步的模块加载方式不适合在浏览器环境中,同步意味着阻塞加载,浏览器资源是异步加载的

2、不能非阻塞的并行加载多个模块

module.exports与exports的区别

1、exports 是指向的 module.exports 的引用

2、module.exports 初始值为一个空对象 {},所以 exports 初始值也是 {}

3、require() 返回的是 module.exports 而不是 exports

exports示例:

// app.jsvar circle = require('./circle');console.log(circle.area(4));// circle.jsexports.area = function(r){ return r * r * Math.PI;}

module.exports示例:

// app.jsvar area = require('./area');console.log(area(4));// area.jsmodule.exports = function(r){ return r * r * Math.PI;}

错误的情况:

// app.jsvar area = require('./area');console.log(area(4));// area.jsexports = function(r){ return r * r * Math.PI;}

其实是对 exports 进行了覆盖,也就是说 exports 指向了一块新的内存(内容为一个计算圆面积的函数),也就是说 exports 和 module.exports 不再指向同一块内存,也就是说此时 exports 和 module.exports 毫无联系,也就是说 module.exports 指向的那块内存并没有做任何改变,仍然为一个空对象{},也就是说area.js导出了一个空对象,所以我们在 app.js 中调用 area(4) 会报 TypeError: object is not a function 的错误。

总结:当我们想让模块导出的是一个对象时, exports 和 module.exports 均可使用(但 exports 也不能重新覆盖为一个新的对象),而当我们想导出非对象接口时,就必须也只能覆盖 module.exports 。

三:模块化进程三:AMD规范

由于浏览器端的模块不能采用同步的方式加载,会影响后续模块的加载执行,因此AMD(Asynchronous Module Definition异步模块定义)规范诞生了。

AMD标准中定义了以下两个API

1、require([module], callback);
2、define(id, [depends], callback);

require接口用来加载一系列模块,define接口用来定义并暴露一个模块。

示例:

define("module", ["dep1", "dep2"], function(d1, d2){ return someExportedValue;});require(["module", "../file"], function(module, file){ /* ... */ });

优点:

1、适合在浏览器环境中异步加载模块

2、可以并行加载多个模块

缺点:

1、提高了开发成本,代码的阅读和书写比较困难,模块定义方式的语义不顺畅

2、不符合通用的模块化思维方式,是一种妥协的实现

四:模块化进程四:CMD规范

CMD(Common Module Definition)规范和AMD很相似,尽量保持简单,并与CommonJS和Node.js的 Modules 规范保持了很大的兼容性。在CMD规范中,一个模块就是一个文件。

示例:

define(function(require, exports, module){ var $ = require('jquery'); var Spinning = require('./spinning'); exports.doSomething = ... module.exports = ...})

优点:

1、依赖就近,延迟执行

2、可以很容易在 Node.js 中运行

缺点:

1、依赖 SPM 打包,模块的加载逻辑偏重

AMD和CMD的区别

AMD和CMD起来很相似,但是还是有一些细微的差别,让我们来看一下他们的区别在哪里:

1、对于依赖的模块,AMD是提前执行,CMD是延迟执行。

2、AMD推崇依赖前置;CMD推崇依赖就近,只有在用到某个模块的时候再去require。看代码:

// AMDdefine(['./a', './b'], function(a, b){ // 依赖必须一开始就写好  a.doSomething()    // 此处略去 100 行  b.doSomething()    ...});// CMDdefine(function(require, exports, module){  var a = require('./a')    a.doSomething()    // 此处略去 100 行  var b = require('./b')  // 依赖可以就近书写  b.doSomething()  // ...});

3、AMD 的 API 默认是一个当多个用,CMD 的 API 严格区分,推崇职责单一。

五:模块化进程五:ES6模块化

EcmaScript6标准增加了JavaScript语言层面的模块体系定义。ES6 模块的设计思想,是尽量的静态化,使得编译时就能确定模块的依赖关系,以及输入和输出的变量。CommonJS和AMD模块,都只能在运行时确定这些东西。

在 ES6 中,我们使用export关键字来导出模块,使用import关键字引用模块。需要说明的是,ES6的这套标准和目前的标准没有直接关系,目前也很少有JS引擎能直接支持。因此Babel的做法实际上是将不被支持的import翻译成目前已被支持的require。

尽管目前使用import和require的区别不大(本质上是一回事),但依然强烈推荐使用import关键字,因为一旦JS引擎能够解析ES6的import关键字,整个实现方式就会和目前发生比较大的变化。如果目前就开始使用import关键字,将来代码的改动会非常小。

示例:

import "jquery";export functiondoStuff(){}module "localModule" {}

优点:

1、容易进行静态分析

2、面向未来的 EcmaScript 标准

缺点:

1、原生浏览器端还没有实现该标准

2、全新的命令字,新版的 Node.js才支持

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!

相关文章

javaScript和jQuery自动加载简单代

javaScript和jQuery自动加载简单代

代码实现,方法,自动加载,简单,电脑软件,在此之前我们给大家整理过用javaScript和jQuery自动加载的几种方法,大家可以参考一下:javaScript 页面自动加载事件详解一、JavaScript自动加载①在文本中用onload: 当页面中所有内容(包括图片)加载完后再…

wps怎么进行文字识别wps进行文字识

wps怎么进行文字识别wps进行文字识

方法,文字识别,文字,图片,输入文字,  wps文字有一个能对图片文字进行识别的功能,你知道这个功能吗?下面小编来告诉你wps进行图片文字识的方法,希望对你有帮助!wps进行图片文字识别的方法wps进行图片文字识别的方法步骤图1wps进行图片文字识…

ppt中怎么插入时间并同步更新ppt中

ppt中怎么插入时间并同步更新ppt中

方法,步骤,同步更新,时间,电脑软件,  ppt中怎么插入时间并同步更新?在制作Powerpoint幻灯片时,需要插入当前时间日期,如果手动输入,那只是一串数字而已,并不能实现同步更新。那么下面小编就教你ppt中插入时间并同步更新的方法。ppt中插入时间…

ppt2010怎么设置单击就实现放大缩

ppt2010怎么设置单击就实现放大缩

单击,放大缩小,设置,方法,图片,  PPT是用于设计制作专家报告、教师授课、产品演示、广告宣传的电子版幻灯片。下面小编教你通过插入对象法实现单击图片放大缩小效果。例如,当鼠标点击图片的时候,图片就放大,当鼠标再次点击图片的时候,图片就…

excel中两列求和的方法教程

excel中两列求和的方法教程

教程,方法,公式,电脑软件,excel,    在excel 中的AB两列各有数据,求两列分别相加的和要怎么求呢?下面小编给你分享了excel中两列求和的教程,以供大家阅读和学习。excel中两列求和的教程两列求和步骤1:例如:要求【A】列和【C】列的和,结果方…

excel2010 模拟分析的教程excel201

excel2010 模拟分析的教程excel201

模拟,教程,电脑软件,strong,  在Excel中录入好数据以后都需要对数据进行分析统计,分析的时候通常需要的是公式的运用。下面是由小编分享的excel2010 模拟分析的教程,希望对你有用。excel2010 模拟分析的教程模拟分析步骤1:设置公式。在b5中…

Word文档中smartart图形功能介绍是

Word文档中smartart图形功能介绍是

图形,文档,详细介绍,功能,电脑软件,  在Word文档中smartart图形的功能非常强大,什么是smartart图形呢?接下来帮助用户认识了解word smartart图形功能。以下是小编为您带来的关于smartart图形功能详细介绍,希望对您有所帮助。smartart图形功…

Excel将当前数据添加到筛选器筛选

Excel将当前数据添加到筛选器筛选

筛选,数据,筛选器,技巧,电脑软件,  有这样一份数据,现在想用Excel的筛选功能,将10多岁和20多岁的人筛选出来。那么应该怎么做呢?以下是小编为您带来的关于Excel将当前数据添加到筛选器筛选技巧,希望对您有所帮助。Excel将当前数据添加到筛选…

excel2007怎样筛选并删除

excel2007怎样筛选并删除

筛选,删除,方法,内容,图片,  在Excel中,有时候输入的数据会非常之多,有些情况需要对条件满足的内容进行删除,这时我们需要用到Excel中的筛选及删除功能,下面给大家分享,希望小编整理的资料对大家有用。excel2007筛选图片内容并删除的方法1:选中…

怎么将ppt2013里面的文字转到Word

怎么将ppt2013里面的文字转到Word

文字,方法,转到,电脑软件,strong,  PPT演讲的成功,不单单是取决于PPT使用和制作技术方面的技巧,还有制作思路方面的学问、演讲方法与技巧等诸多方面。现在很多大型公司,进行PPT幻灯片演讲是一种主流了。演讲结束,将演示文稿发给观众查看,一…

WPS表格如何给某列的所有数值批量

WPS表格如何给某列的所有数值批量

增减,数值,批量,表格,电脑软件,  给某一个列的所有数值增加一个相同的固定值,在某些情况下还是比较实用的。以下是小编为您带来的关于WPS表格给某列的所有数值批量增减相同的固定值,希望对您有所帮助。WPS表格给某列的所有数值批量增减相同…

word2016文档替换文字时如何区分大

word2016文档替换文字时如何区分大

大小写,替换,文字,文档,时区,  很多朋友在使用word2016时替换文字想要区分大小写,不知道怎么操作,word2016替换文字区分大小写的方法很简单。以下是小编为您带来的关于word2016替换文字时区分大小写,希望对您有所帮助。word2016替换文字时区…