详谈js模块化规范


Posted in Javascript onJuly 07, 2017

1. CommonJS

用于服务端模块化编程,比如nodejs就采用此规范;

一个文件就是一个模块,require方法用来加载模块,该方法读取一个文件并执行,最后返回文件内部的module.exports对象;

require是默认读取.js文件的,所以require(模块名)可以不写后缀;

同步加载,由于服务端加载的模块一般在本地,所以可以这样;但是在客户器端如果一个模块过大就会导致页面“假死”;

module.exports属性表示当前模块对外输出的接口,其他文件加载该模块,实际上就是读取module.exports变量;为了方便也可以用exports,exports指向module.exports;即exports = module.exports = {}

exports.xxx相当于在导出的对象上添加属性,该属性对调用模块可见;

exports =  相当于给exports重新赋值,这样就切断了和module.exports的关联,调用模块就不能访问exports的对象及其属性;

2. AMD

加载模块:require([module], function(module){});

定义模块:define([module], function(module){});module为依赖模块;

require.js(前端模块化管理的工具库)实现js文件的异步加载,避免网页失去响应;管理模块之间的依赖性,便于代码的编写和维护。

依赖前置,尽早的执行模依赖块,执行顺序不一定是先1后2;

加载非规范的模块

require.config({
 baseUrl: "js/lib",
 paths: {
  "jquery": "jquery.min",
 "underscore": "underscore.min",

 "backbone": "backbone.min"
  },
 shim: {
  'underscore':{
   exports: '_'

 },

 'backbone': {


deps: ['underscore', 'jquery'],


exports: 'Backbone'

 }
 }
});
// exports值(输出的变量名),表明这个模块外部调用时的名称;deps数组,表明该模块的依赖性

3. CMD

define(function(require, exports, module){
 var a = require('a');
 a.foo();
};

Sea.js

依赖就近,且在真正需要使用依赖模块时才执行该模块,顺序固定;

AMD和CMD最大的区别是对依赖模块的执行时机处理不同,而不是加载的时机或者方式不同,二者皆为异步加载模块;

AMD依赖前置,js可以方便知道依赖模块是谁,立即加载;而CMD就近依赖,需要使用把模块变为字符串解析一遍才知道依赖了那些模块

以上这篇详谈js模块化规范就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery.ui.draggable中文文档(原文翻译)
Nov 15 Javascript
JavaScript加入收藏夹功能(兼容IE、firefox、chrome)
May 05 Javascript
javascript实现动态导入js与css等静态资源文件的方法
Jul 25 Javascript
基于Jquery实现焦点图淡出淡入效果
Nov 30 Javascript
jquery操作select元素和option的实例代码
Feb 03 Javascript
node.js连接mongoDB数据库 快速搭建自己的web服务
Apr 17 Javascript
Vue修改mint-ui默认样式的方法
Feb 03 Javascript
解决vue-cli webpack打包后加载资源的路径问题
Sep 25 Javascript
微信小程序picker组件关于objectArray数据类型的绑定方法
Mar 13 Javascript
详解如何给React-Router添加路由页面切换时的过渡动画
Apr 25 Javascript
微信小程序实现一个简单swiper代码实例
Dec 30 Javascript
Jquery 获取相同NAME 或者id删除行操作
Aug 24 jQuery
使用JavaScript实现alert的实例代码
Jul 06 #Javascript
vuejs手把手教你写一个完整的购物车实例代码
Jul 06 #Javascript
Vue axios 中提交表单数据(含上传文件)
Jul 06 #Javascript
解决webpack打包速度慢的解决办法汇总
Jul 06 #Javascript
详解微信小程序Radio选中样式切换
Jul 06 #Javascript
Node.js 回调函数实例详解
Jul 06 #Javascript
详解vue渲染从后台获取的json数据
Jul 06 #Javascript
You might like
PHP正则验证Email的方法
2015/06/15 PHP
Zend Framework常用校验器详解
2016/12/09 PHP
PHP+Ajax简单get验证操作示例
2019/03/02 PHP
js getBoundingClientRect() 来获取页面元素的位置
2010/11/25 Javascript
JS限制Textarea文本域字符个数的具体实现
2013/08/02 Javascript
jquery中插件实现自动添加用户的具体代码
2013/11/15 Javascript
使用pcs api往免费的百度网盘上传下载文件的方法
2016/03/17 Javascript
jquery跟随屏幕滚动效果的实现代码
2016/04/13 Javascript
Javascript将字符串日期格式化为yyyy-mm-dd的方法
2016/10/27 Javascript
JS用斜率判断鼠标进入DIV四个方向的方法
2016/11/07 Javascript
详解js产生对象的3种基本方式(工厂模式,构造函数模式,原型模式)
2017/01/09 Javascript
jQuery实现单击按钮遮罩弹出对话框效果(1)
2017/02/20 Javascript
vuejs使用FormData实现ajax上传图片文件
2017/08/08 Javascript
浅谈js基础数据类型和引用类型,深浅拷贝问题,以及内存分配问题
2017/09/02 Javascript
从零开始搭建vue移动端项目到上线的步骤
2018/10/15 Javascript
微信小程序自定义弹窗wcPop插件
2018/11/19 Javascript
js中Array对象的常用遍历方法详解
2019/01/17 Javascript
微信小程序实现吸顶特效
2020/01/08 Javascript
如何在vue 中使用柱状图 并自修改配置
2021/01/21 Vue.js
python django事务transaction源码分析详解
2017/03/17 Python
Python图片裁剪实例代码(如头像裁剪)
2017/06/21 Python
Python复制Word内容并使用格式设字体与大小实例代码
2018/01/22 Python
python 除法保留两位小数点的方法
2018/07/16 Python
pytorch nn.Conv2d()中的padding以及输出大小方式
2020/01/10 Python
浅谈Python协程
2020/06/17 Python
python 实现批量图片识别并翻译
2020/11/02 Python
公务员年总结的自我评价
2013/10/25 职场文书
汽车运用工程毕业生自荐信
2013/10/29 职场文书
工作交流会欢迎词
2014/01/12 职场文书
《青海高原一株柳》教学反思
2014/04/25 职场文书
2014年度党员自我评议
2014/09/13 职场文书
2014迎国庆演讲稿
2014/09/19 职场文书
酒店前台岗位职责
2015/04/16 职场文书
2015年小学辅导员工作总结
2015/05/27 职场文书
python-for x in range的用法(注意要点、细节)
2021/05/10 Python
微信小程序中wxs文件的一些妙用分享
2022/02/18 Javascript