js的四种模块化引入规范

1、AMD

AMD是一种加载方式,异步加载模块,不占用主进程的代码执行

AMD规范依赖于require.js,来完成

模块放在数组一块加载

AMD推崇依赖前置,在定义模块的时候就要声明其依赖的模块,预加载

AMD的执行需要引入require.js文件

API

define

定义模块

他有两个参数,第一个用于声明需要加载的依赖模块,他是一个数组;

第二个是模块加载成功后的回调函数,这个回调函数相当于这个模块文件的代码区域,该模块的代码是在这个函数中添加的。回调函数的参数依次是每个加载的依赖模块

require.config

require方法本身是个对象他有一个config方法,用来配置requirejs运行。

这个方法接受一个对象,对象中有若干属性。

paths,它用于配置模块的加载路径

仅导出模块

define(function () {
    var msg="这是第一个模块";
    function getMsg() {
        return msg;
    }
    return {
        getMsg
    }
})

导入、导出模块

require.config({ //配置模块
    paths:{
        mod1:"mod1",
        mod2:"mod2",
        mod3:"mod3"
    }
});

define(["mod1","mod2","mod3"],function (mod1,mod2,mod3) { //加载模块,回调函数中来定义该模块的代码,用于导出
    var msgAll=mod1.getMsg()+mod2.getMsg()+mod3.getMsg();
    function getMsg(){
        return msgAll;
    }
    return { //导出模块
        getMsg
    }
})

引入模块

<script src="./amd/require.js" data-main="./amd/index.js"></script>

在script标签加载requirejs文件,添加data-main标签属性用于指定加载的模块

2、CMD

同步加载模块方式,他也可以实现异步加载

CMD规范的实现基于Sea.js文件

CMD加载模块是一个个的加载的

CMD推崇就近依赖,只有在用到某个模块的时候再去require引入,

API

define

传入一个函数,函数有三个参数,require、exports、module

require用于加载依赖的文件

exports与module是模块导出的方式

导出模块

导出方式两种

module.export={} //定义没有依赖的模块

export.xxx={} //定义有依赖的模块

没有依赖模块导出

define function(require, exports, module){
    exports.xxx = value;
    module.exports = value
}

有依赖模块导出

define function(require, exports, module){
    var module2 = require("./module2");
    exports.xxx = value
}

引入模块

<script src="./cmd/cmd.js"></script> //引入Sea.js文件
<script>
    seajs.use("./cmd/index.js"); //使用seajs.use 这种语法来引入模块
</script>

3、Es6模块化

javascript在早期并没有模块化的方式,要是用模块化需要依赖第三方框架 requirejs、Seajs

Es6引入了模块化的概念

他的优点

每一个模块只加载一次, 并只执行一次,重复加载同一文件,直接从内存中读取;

每一个模块内声明的变量都是局部变量, 不会污染全局作用域;

通过export导出模块,通过import导入模块

ES6模块只支持静态导入和导出,只可以在模块的最外层作用域使用import和export

在es6的import导入时要是用 as 来使用别名

导出模块

两种方法

export default

将模块方法一并导出一个对象,他只能导出一次,统一暴露模块的接口,这种导出方式可以在引入的时候自定义模块名

export default { //通过对象的形式导出
    mainMeg,
    mainMeg1
}

export

他通过在变量前声明的形式,来暴露这个接口,export可以重复使用,来暴露若干个,最终将这些暴露的接口放入一个对象中。

因为最终导出的是一个对象,在接受的时候,用解构赋值的形式来将他们提取出来,如果想要使用别名的话要用 as

export function mainMeg() {
    console.log("aaa");
}

export function mainMeg1() {
    console.log("bbb");
}

export与export default混合使用

1、export导出的接口并没有放在export default导出的对象中

2、export default导出的对象后依然可以继续用export来导出

3、export与export default导出的接口要用他们对应的方式引入

导入模块

export function mainMeg() {
    console.log("aaa");
}

function mainMeg2() {
    console.log("ccc");
}

function mainMeg3() {
    console.log("ddd");
}

export default {
    mainMeg2,
    mainMeg3
}

export function mainMeg4() {
    console.log("eee");
}

Es6的导入要先在script标签中设置模块引入方式,

<script type="module"> //声明引入方式

    import mode from "./es6/index.js"; //引入export default导出的对象

    import {mainMeg as play,mainMeg1,mainMeg4} from "./es6/index.js"; //引入export导出的接口

</script>

4、CommonJs

服务器同步加载模块规范

Node 应用由模块组成,采用 CommonJS 模块规范。

import {ajaxSend as ajax} from "./modules/ajax.js";

模块导出

1、运用了module.exports={} 语法导出,他会导出一个对象,对象中存储模块暴露的接口,这样一次性的导出

2、也可以通过module.exports.xxx=xxx 来向导出对象中添加导出的接口

3、为了方便,Node为每个模块提供一个exports变量,指向module.exports。这等同在每个模块头部,有一行这样的命令,var exports = module.exports;

但是注意,不能直接将exports变量指向一个值,因为这样等于切换了引用地址,切断了exports与module.exports的联系,并没有在module.exports内添加任何接口

可以通过exports.xxx=xxx 来向module.exports对象中添加属性

模块引入

简单地一句话将模块module.exports对象引入

var mod1=require("./mod1");

可以用解构赋值,来提取其中的方法

var {getMsg}=require("./mod1");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值