[JS] JS模块化开发之RequireJS
本节将简述RequireJS常用的功能
RequireJS 实现了 Asynchronous Module API.
目录:
Nuget:Install-Package RequireJS(会包含2个文件.r.js是用来通过nodejs压缩js的)
为什么使用RequireJS
- 加载script标签会停止响应
- js文件存在依赖性
- 模块化开发
加载RequireJS
- 异步加载script
<script src="scripts/require.js" defer async="true"></script>
- 加载自定义js
<script src="scripts/require.js" data-main="scripts/main"></script>
RequireJS函数
- require.config({}):配置Require信息
包括baseUrl,paths,shim,map,enforceDefine
- require([],funcLoad,funcErro):加载模块后,执行方法
- define([],func):加载模块,定义模块
Hello World
- 加载requirejs
<script data-main="main" src="Scripts/require.js"></script>
- 编写main.js
require.config({
baseUrl: 'Scripts',
paths: {
jquery: ['//cdn.bootcss.com/jquery/2.2.3/jquery', 'jquery-2.2.4']
}
});
require(['jquery'], function (a) {
alert(a.fn.jquery);
});
- baseUrl默认与mainjs同一目录
- paths支持多个js源
- paths默认为地址加上.js
- require第一个参数为依赖的模块
- require第二个参数方法中的变量名依次与依赖模块一一对应
自定义模块
定义1个Cache模块,缓存页面中的js对象.
define(['jquery'], function ($) {
var cache = {};
return {
set: function (key, val) {
cache[key] = val;
},
get: function (key) {
return cache[key];
}
}
});
main.js
require(['cache'], function (cache) {
alert(jQuery.fn.jquery);
cache.set('a', 'hello');
});
require(['cache'], function (cache) {
alert(cache.get('a'));
});
引入第三方插件
很多js库 并没有支持AMD方式的模块化开发.
本例子实现上面的cache功能
定义cached.js
var cache = {
data: {},
set: function (key, val) {
this.data[key] = val;
},
get: function (key) {
return this.data[key];
}
};
main.js
require.config({
baseUrl: 'Scripts',
paths: {
jquery: ['//cdn.bootcss.com/jquery/2.2.3/jquery', 'jquery-2.2.4']
},
shim: {
cached: {
exports: 'cache',
deps: ['jquery']
}
}
});
require(['cached'], function (cache) {
cache.set('a', 'hello');
});
require(['cached'], function (cache) {
alert(cache.get('a'));
});
- shim解决依赖与非AMD载入方式.
- exports指定js中提供的对象或方法名.
- deps指定依赖的js库
多版本js库处理
我们的项目如果使用新版本js功能,但又不能直接替换老版本的js.多个版本共存的时候.
使用map函数
requirejs.config({
map: {
'*': {
'jquery': 'scripts/jquery-2.2.4'
},
'scripts/cache': {
'jquery': '//cdn.bootcss.com/jquery/2.2.3/jquery.js'
}
}
});
require(['scripts/cache'], function (a) {
alert($.fn.jquery);
});
map定义了2种jquery版本
*表示默认情况下的jquery模块使用本地2.2.4
scripts/cache表示模块名为此的时候,jquery使用远程库.远程库需添加js扩展名.
RequireJS插件
https://github.com/requirejs/requirejs/wiki/Plugins
AMD(中文版):
https://github.com/amdjs/amdjs-api/wiki/AMD-(%E4%B8%AD%E6%96%87%E7%89%88)
[JS] JS模块化开发之RequireJS的更多相关文章
- Asp.net Mvc模块化开发之“开启模块开发、调试的简单愉快之旅”
整个世界林林种种,把所有的事情都划分为对立的两个面. 每个人都渴望的财富划分为富有和贫穷,身高被划分为高和矮,身材被划分为胖和瘦,等等. 我们总是感叹,有钱人的生活我不懂;有钱人又何尝能懂我们每天起早 ...
- Asp.net Mvc模块化开发之“部分版本部分模块更新(上线)”
项目开发从来就不是一个简单的问题.更难的问题是维护其他人开发的项目,并且要修改bug.如果原系统有重大问题还需要重构. 怎么重构系统不是本文探讨的问题,但是重构后如何上线部署和本文关系密切.这个大家可 ...
- 模块化开发之sea.js
随着时间的推移,原生js越来越强大,es6中的improt,export已经可以实现模块化开发,但可惜的是现在的浏览器还不支持,需要进行编译,相信在不久的将来,一定会大行其道,今天我们来聊聊模块化开发 ...
- 模块化开发之sea.js实现原理总结
seajs官网说:seajs是一个模块加载器,所以学习它并不难. 在我的理解就是:本来我们是需要手动创建 script标签 引入 js文件的,但用seajs后,它就自动帮我们完成这些工作. 这里只说实 ...
- 项目伪模块化开发之:requirejs(AMD)开发
附:伪模块开发,终将会被es6的模块开发取代.其只为过渡阶段使用 一.为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码 ...
- HTML5+JS手机web开发之jQuery Mobile初涉
一.起始之语 我一直都是在PC上折腾网页的,这会儿怎么风向周边捣鼓起手机网页开发呢?原因是公司原先使用Java开发的产品,耗了不少人力财力,但是最后的效果却不怎么好.因为,Android系统一套东西, ...
- 前端模块化开发之seaJs
了解后端语言的童鞋一定听过模块化开发的概念,比如java.python等后端语言都有自己的模块化特性,然而和后端语言相比,javascript还尚未实现模块化的功能,虽然之后的更高版本可能引入模块化开 ...
- 模块化开发之Amd规范和Cmd规范
CMD规范:是SeaJS 在推广过程中对模块定义的规范化产出的. AMD规范:是 RequireJS 在推广过程中对模块定义的规范化产出的 // CMD define(function(require ...
- 模块化开发之butterknife 在 library中使用
在Android开发中butterknife是一个很好的对资源初始化的工具,它可以使你的代码简洁通俗易懂,同时配合Android ButterKnife Zelezny插件可以让你写代码的速度提升至少 ...
随机推荐
- SQL SERVER 2012 只能识别20个CPU的问题
背景 最近在给客户优化时时候发现客户的虚拟机环境分配了32C 但是只能识别20个,物理机64C,64G内存,本来没什么,CPU利用率在40%左右,但是优化后同时增加了 CPU和内存的分配,CPU32增 ...
- RCP:【转载】插件无法启动的解决方案
有空了再翻译吧…… Table 2. Run configuration problems Problem Investigate During start you get error message ...
- 写了一个简单的NodeJS实现的进程间通信的例子
1. cluster介绍 大家都知道nodejs是一个单进程单线程的服务器引擎,不管有多么的强大硬件,只能利用到单个CPU进行计算.所以,有人开发了第三方的cluster,让node可以利用多核CPU ...
- Java多线程4:synchronized锁机制
脏读 一个常见的概念.在多线程中,难免会出现在多个线程中对同一个对象的实例变量进行并发访问的情况,如果不做正确的同步处理,那么产生的后果就是"脏读",也就是取到的数据其实是被更改过 ...
- Java虚拟机2:Java内存区域及对象
几个计算机的概念 为以后写文章考虑,也为巩固自己的知识和一些基本概念,这里要理清楚几个计算机中的概念. 1.计算机存储单位 从小到大依次为位Bit.字节Byte.千字节KB.兆M.千兆GB.TB,相邻 ...
- 作业七:团队项目——Alpha版本冲刺阶段-14
组内成员进行测试,对一些小问题进行了修改.
- (翻译)反射处理java泛型
当我们声明了一个泛型的接口或类,或需要一个子类继承至这个泛型类,而我们又希望利用反射获取这些泛型参数信息.这就是本文将要介绍的ReflectionUtil就是为了解决这类问题的辅助工具类,为java. ...
- jQuery疑惑记录
不断更新 1.项目中有一句 this.$html = $('<div/>').html(html).attr('sspa-mod-id', this.modName).hide();不知道 ...
- 每天一个linux命令(56):netstat命令
netstat命令用于显示与IP.TCP.UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况.netstat是在内核中访问网络及相关信息的程序,它能提供TCP连接,TCP和UD ...
- OutputCache属性详解(四)— SqlDependency
目录 OutputCache概念学习 OutputCache属性详解(一) OutputCache属性详解(二) OutputCache属性详解(三) OutputCache属性详解(四)— SqlD ...