一.模块前端
之前使用JS的方式要更改,之前只能说是JS的最初级应用,如今对JS应该使用模块化写法.编程
好处:数组
模块就是实现特定功能的文件,把几个函数放在一个文件里就构成了一个模块。须要的时候加载这个文件,调用其中的函数便可。
但这样作会污染全局变量,没法保证不与其余模块发生变量名冲突,并且模块成员之间没什么关系。浏览器
简单的例子:服务器
var module = (function(){ var star = 0; var f1 = function (){ alert('ok'); }; var f2 = function (){ //... }; return { f1:f1, f2:f2 }; })(); module.f1(); //ok alert(module.star) //undefined 由于start并无return出来
二.CommonJs异步
CommonJS是服务器端模块的规范,由Node推广使用。因为服务端编程的复杂性,若是没有模块很难与操做系统及其余应用程序互动。模块化
根据CommonJS规范:函数
global
对象的属性。输出模块变量的最好方法是使用module.exports
对象。requirejs
加载模块使用require
方法,该方法读取一个文件并执行,返回文件内部的module.exports
对象ui
用一套标准模板来封装模块定义:
define(function(require, exports, module) { // The module code goes here });
这套模板代码为模块加载器提供了机会,使其能在模块代码执行以前,对模块代码进行静态分析,并动态生成依赖列表。
math.js define(function(require, exports, module) { exports.add = function() { var sum = 0, i = 0, args = arguments, l = args.length; //arguments表明入参.与Array类型相似.arguments[0],arguments[1] while (i < l) { sum += args[i++]; } return sum; }; }); increment.js define(function(require, exports, module) { var add = require('math').add; exports.increment = function(val) { return add(val, 1); }; }); index.js define(function(require, exports, module) { var inc = require('increment').increment; inc(1); // 2 });
它采用异步方式加载模块,模块的加载不影响它后面语句的运行。全部依赖这个模块的语句,都定义在一个回调函数中,等到加载完成以后,这个回调函数才会运行。
1.RequireJS
主要解决两个问题
2.RequireJS API 存在于RequireJS载入时建立的命名空间requirejs下。
其主要API主要是下面三个函数:
3.配置函数
若是你想改变RequireJS的默认配置来使用本身的配置,你可使用require.configh函数。config函数须要传入一个可选参数对象,这个可选参数对象包括了许多的配置参数选项。下面是一些你可使用的配置:
CMD 即Common Module Definition
通用模块定义,CMD规范是国内发展出来的,就像AMD有个requireJS
,CMD有个浏览器的实现SeaJS
,SeaJS
要解决的问题和requireJS
同样,只不过在模块定义方式和模块加载(能够说运行、解析)时机上有所不一样。
在 CMD 规范中,一个模块就是一个文件。代码的书写格式以下:
define(function(require, exports, module) { // 模块代码 });
require
是能够把其余模块导入进来的一个参数;而exports
是能够把模块内的一些属性和方法导出的;module
是一个对象,上面存储了与当前模块相关联的一些属性和方法。
差别:
AMD是依赖关系前置,在定义模块的时候就要声明其依赖的模块;
CMD是按需加载依赖就近,只有在用到某个模块的时候再去require:
// CMD define(function(require, exports, module) { var a = require('./a') a.doSomething() // 此处略去 100 行 var b = require('./b') // 依赖能够就近书写 b.doSomething() // ... }) // AMD 默认推荐的是 define(['./a', './b'], function(a, b) { // 依赖必须一开始就写好 a.doSomething() // 此处略去 100 行 b.doSomething() ... })
主要是Sea.js的使用.