模块化在项目中十分的重要,一个复杂的项目肯定有很多相似的功能模块,如果每次都需要重新编写模块肯定既费时又耗力。但是引用别人编写模块的前提是要有统一的“打开姿势”,如果每个人有各自的写法,那么肯定会乱套,下面介绍几种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.js
var circle = require('./circle');
console.log(circle.area(4));
// circle.js
exports.area = function(r){
return r * r * Math.PI;
}
module.exports示例:
// app.js
var area = require('./area');
console.log(area(4));
// area.js
module.exports = function(r){
return r * r * Math.PI;
}
错误的情况:
// app.js
var area = require('./area');
console.log(area(4));
// area.js
exports = 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。看代码:
// AMD
define(['./a', './b'], function(a, b){ // 依赖必须一开始就写好
a.doSomething()
// 此处略去 100 行
b.doSomething()
...
});
// CMD
define(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
# 模块化
# javascript模块化编程
# javascript模块化写法
# 详解Js中的模块化是如何实现的
# Javascript模块化编程详解
# 详解JavaScript模块化开发
# JavaScript 模块化详解
# 详谈js模块化规范
# 拥抱模块化的JavaScript
# 前端JavaScript模块化解析之ESModule用法示例
# 加载
# 的是
# 多个
# 也就是说
# 是一个
# 他们的
# 会报
# 很相似
# 都是
# 这是
# 就会
# 还没有
# 是一种
# 让我们
# 有很多
# 每个人
# 要有
# 已被
# 推荐使用
# 很容易
相关文章:
制作旅游网站html,怎样注册旅游网站?
如何通过NAT技术实现内网高效建站?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
太平洋网站制作公司,网络用语太平洋是什么意思?
,在苏州找工作,上哪个网站比较好?
高端建站如何打造兼具美学与转化的品牌官网?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
如何选择域名并搭建高效网站?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?
如何注册花生壳免费域名并搭建个人网站?
家庭服务器如何搭建个人网站?
平台云上自主建站:模板化设计与智能工具打造高效网站
南平网站制作公司,2025年南平市事业单位报名时间?
如何快速查询域名建站关键信息?
如何在万网主机上快速搭建网站?
建站之星价格显示格式升级,你的预算足够吗?
如何在建站之星绑定自定义域名?
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
网站图片在线制作软件,怎么在图片上做链接?
完全自定义免费建站平台:主题模板在线生成一站式服务
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
宝塔面板如何快速创建新站点?
在线教育网站制作平台,山西立德教育官网?
网站制作服务平台,有什么网站可以发布本地服务信息?
建站上传速度慢?如何优化加速网站加载效率?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
如何快速搭建高效可靠的建站解决方案?
如何基于云服务器快速搭建个人网站?
网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
如何在云虚拟主机上快速搭建个人网站?
浅谈Javascript中的Label语句
网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?
公司网站制作需要多少钱,找人做公司网站需要多少钱?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
网站按钮制作软件,如何实现网页中按钮的自动点击?
建站之星CMS五站合一模板配置与SEO优化指南
网站制作壁纸教程视频,电脑壁纸网站?
定制建站方案优化指南:企业官网开发与建站费用解析
微信小程序 五星评分(包括半颗星评分)实例代码
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
c++怎么用jemalloc c++替换默认内存分配器【性能】
Thinkphp 中 distinct 的用法解析
php条件判断怎么写_ifelse和switchcase的使用区别【对比】
*请认真填写需求信息,我们会在24小时内与您取得联系。