博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
javascript模块化详解
阅读量:6361 次
发布时间:2019-06-23

本文共 2056 字,大约阅读时间需要 6 分钟。

模块化:每个模块只完成一个独立的功能,然后提供该功能的接口。模块间通过接口访问。模块中的(过程和数据)对于其它模块来说是私有的(不能访问修改)

原始人写法:

1 function m1(){2   //...3 }4 function m2(){5   //...6 }

 

对象封装写法

1 var loveThing = {2   mylove : "coding",3   getLove :function() {4     returnthis.mylove;5   },6   sayLove : function(thing) {7     console.log(thing);8   }9 }
1 console.log(loveThing.getLove());//>>> coding2 loveThing.sayLove('girl');//>>> girl

这种写法已经有点模块的样子了,一下就能看出这几个函数和变量之间的联系。

缺点在于所有变量都必须声明为公有所以都要加this指示作用域以引用这些变量。更危险的是,在对象之外也能轻松更改里面的参数:

1 loveThing.mylove = "sleeping";2 console.log(loveThing.getLove());//>>> sleeping

 

立即执行函数

外部可以访问my这个接口,但以下代码(过程和数据)对于其它模块来说是私有的

以下这种方法返回一个对象,让其他模块去调用

1 var loveThing = (function(){  2     var my = {};  3     var love = "coding";  4      my.getLove = function() {  5         return love;  6      }  7      my.sayLove = function(thing) {  8         console.log(thing);  9      } 10      return my; 11 })(); 12 console.log(loveThing.getLove());//>>> coding loveThing.sayLove('reading');//>>> reading

将局部的函数提升到 windows 下面,可以让其他地方使用。

1 (function(){2   // private code3     var  a = function(){4      5   }6   window.a = a;7 })();

我们试着获取里面的变量:

1 console.log(loveThing.love);//>>> undefined

果然,外部根本看不见里面的零件只能使用提供的接口这样才能保证私有变量的安全。 

 

输入全局变量

独立性是模块的重要特点,模块内部最好不与程序的其他部分直接交互。为了在模块内部调用全局变量,必须显式地将其他变量输入模块。

下面除了保证模块的独立性,还使得模块之间的依赖关系变得明显。

1 var module1 = (function ($,) {2     //...3 })(jQuery,);

 

CommonJSAMD

目前,通行的Javascript模块规范共有两种:CommonJSAMD

 

最近在学习node,node.js的模块系统,就是参照CommonJS规范实现的。只使用require(),用得一个爽字

 

例如:
1 var math = require('math');

然后,就可以调用模块提供的方法:

1 var math = require('math'); 2 math.add(2,3); // 5

然而,由于一个重大的局限,使得CommonJS规范不适用于浏览器环境。还是上一节的代码,如果在浏览器中运行,会有一个很大的问题,你能看出来吗? 

第二行math.add(2, 3),在第一行require('math')之后运行,因此必须等math.js加载完成。也就是说,如果加载时间很长,整个应用就会停在那里等。

因此,浏览器端的模块,不能采用"同步加载"(synchronous),只能采用"异步加载"(asynchronous)。这就是AMD规范诞生的背景。 

 

AMD是"Asynchronous Module Definition"的缩写,意思就是"异步模块定义"。require.js实现了AMD规范

AMD也采用require()语句加载模块,但是不同于CommonJS,它要求两个参数

require([module], callback); 

  • [module]:数组,要加载的模块;
  • callback:加载成功之后的回调函数。

 

转载于:https://www.cnblogs.com/beidan/p/5289702.html

你可能感兴趣的文章
linux-centos7搭建本地yum服务并使用
查看>>
For input string: "null"
查看>>
『高级篇』docker之微服务业务分析(九)
查看>>
安装、登录CentOS7
查看>>
selenium处理嵌套iframe
查看>>
通过思科模拟器CISCO PACKET TRACER学习网络3——初步认识VLAN
查看>>
我的友情链接
查看>>
解决开机POST提示Strike tne F1 key to continue,F2 to run the setup utility
查看>>
Java数据结构----栈(Stack)源码分析和个人简单实现
查看>>
codis集群完整搭建过程详解
查看>>
LVS介绍以及部署
查看>>
Centos6 安装cdh5.7
查看>>
Outlook 2010添加Exchange Online用户
查看>>
VSS6.0 admin密码清除
查看>>
git status遇到old mode问题
查看>>
字符,字节和编码 一
查看>>
强制关闭数据库
查看>>
502错误详解
查看>>
ARM开发板 嵌入式Linux 修改开机启动LOGO
查看>>
Baby-gin
查看>>