Javascript模块化编程-require.js[3]
很多情况下,JS都是放到一个或者多个文件里,只要加载这些文件就可以了。
但是对于一些小型项目而言,这种写法是没有任何问题的。
但是对于某些大型网站,JS的量是很大的,如果还采用这种方式,网站时常在加载时,出现假死的现象。
为了解决这个问题,require.js应运而生。
1、require.js的核心
1、实现js文件异步加载,避免网站失去响应。
2、管理模块之间的依赖性,便于代码的编写和维护。
2、require.js的加载
在网页加载require.js时,需要实现如下写法:
<script src="js/require.js" defer async="true" data-main="js/jsname"></script>
defer兼容IE。
async=“true”兼容其它常规浏览器。
data-main属性的作用:加载当前网页的主模块。
3、主模块的写法
主模块即当前网页的主程序。
主模块依赖其它模块,此时,需要AMD规范定义require()函数。
Eg:
require(['moduleA','moduleB','moduleC',function(moduleA,moudleB,moduleC){
//...
}]);
第一个参数:所依赖的各个模块的全局名称。
第二个参数:回调函数,当前模块加载成功后,该函数将被调用。加载模块会以参数的形式传入改函数。
4、模块的配置
require.config()方法,实现了对模块加载行为的自定义。require.config()定义在主模块的头部。
Eg:
require.config({
paths:{
"jquery":"juqery.min",
...
}
});
如果子模块在主模块的同级目录的子目录下,那写法为:
Eg:
require.config({
paths:{
"jquery":"lib/juqery.min",
...
}
});
或
require.config({
baseUrl:"js/lib",
paths:{
"jquery":"lib/juqery.min",
...
}
});
require.js要求,每个模块是一个单独的js文件。如果加载多个模块时,此时需要发出多次http请求,那么加载速度方面就会大大折扣。
require.js提供了一个优化工具,当模块部署完毕后,可以用这个工具将多个模块合并在一个文件中。
5、AMD模块写法
require.js加载的模块,采用AMD规范。
定义模块,需要采用特定的define()函数来定义,以test.js为例。
定义不依赖其它模块的写法:
define(function(){
var fn1=function(obj){
return obj;
};
return{
op:fn1
};
});
定义依赖其它模块的写法:
define(['mytest'],function(mytest){
function test(){
//...
}
return {
ta:test
};
});
主模块或者别的模块调用的写法:
require(['test'],function(test){
//...
});
6、非AMD规范模块写法
理论上,require.js加载模块,必须按照AMD规范、必须用define()函数定义模块。
例如:JQuery等。,现实环境中,也会出现非AMD规范的模块,require.js也实现了对非AMD规范的模块的兼容。
实现对非AMD模块的兼容,需要用require.config()进行配置,定义他们的特征。
Eg:
jQuery插件可以这样定义:
require.config({
shim:{
'jQuery.scroll':{
deps:['jQuery'],
exports:'jQuery.fn.scroll'
}
}
});
deps,模块的依赖。
exports,输出的变量名,别的模块调用这个模块时的名称。
7、require.js插件
require.js还提供了一些插件。
json和mdown插件。
domready插件,可以让回调函数在也页面DOM结构加载完成后再运行。
Eg:
require(['domready!'],function(doc){
//...
});
text和image插件,允许require.js加载文本和图片文件。
define(
['text!review.txt','image!cat.jpg'],
function(review,cat){
console.log(review);
document.body.appendChild(cat);
}
);
【上一章节】 【下一章节】
Javascript模块化编程-require.js[3]的更多相关文章
- 坑人的 Javascript 模块化编程 require.js
坑人的 Javascript 模块化编程 require.js
- Javascript模块化编程require.js的用法
JS模块化工具requirejs教程(一):初识requirejs http://www.runoob.com/w3cnote/requirejs-tutorial-1.html JS模块化工具req ...
- Javascript模块化编程 require.js使用详解
一.为什么用require.js,产生的背景 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载. & ...
- 坑人的 Javascript 模块化编程 sea.js
坑人的 Javascript 模块化编程 sea.js 忧伤 加 蛋疼的 开始了 看文档 Sea.js 进行配置 seajs.config({ // 设置路径,方便跨目录调用 paths: { 'ar ...
- Javascript模块化工具require.js教程
转自:http://www.w3cschool.cc/w3cnote/requirejs-tutorial-1.html, http://www.w3cschool.cc/w3cnote/requir ...
- JavaScript模块化-require.js,r.js和打包发布
在JavaScript模块化和闭包和JavaScript-Module-Pattern-In-Depth这两篇文章中,提到了模块化的基本思想,但是在实际项目中模块化和项目人员的分工,组建化开发,打包发 ...
- Javascript模块化编程(三):require.js的用法
Javascript模块化编程(三):require.js的用法 原文地址:http://www.ruanyifeng.com/blog/2012/11/require_js.html 作者: 阮一峰 ...
- Javascript模块化编程之路——(require.js)
转自:http://www.ruanyifeng.com/blog/2012/10/javascript_module.html Javascript模块化编程(一):模块的写法 随着网站逐渐变成&q ...
- (转)Javascript模块化编程(三):Require.js的用法
转自 ruanyifeng 系列目录: Javascript模块化编程(一):模块的写法 Javascript模块化编程(二):AMD规范 Javascript模块化编程(三):Require.js的 ...
随机推荐
- Codeforces 815 C Karen and Supermarket
On the way home, Karen decided to stop by the supermarket to buy some groceries. She needs to buy a ...
- 两个本质相同的dp
1.划分数 描述:给定数字N,将其划分为不超过K组,求不同的划分的总数(比如4——1 2 1,2 1 1就算做一种划分) 2.Dollar Dayz 描述:给定数字N,将其随意划分,但是组成数字不可以 ...
- Artix : Arch拥抱OpenRC 使用笔记
轻量桌面Archlinux用户逃离systemd,拥抱Gentoo的openrc. 镜像源:官方镜像源非常慢,曾经一度体验artix后就放弃了,后来发现了清华和腾讯云的镜像,速度非常快,现在又重新安装 ...
- 【转】如何利用多核CPU来加速你的Linux命令 — awk, sed, bzip2, grep, wc等
如何利用多核CPU来加速你的Linux命令 — awk, sed, bzip2, grep, wc等 你是否曾经有过要计算一个非常大的数据(几百GB)的需求?或在里面搜索,或其它操作——一些无法并 ...
- ZRender实现粒子网格动画实战
注:本博文代码基于ZRender 3.4.3版本号开发,相应版本号库地址:ZRender 库. 效果 实现分析 通过上面显示的效果图,能够看出,这样的效果就是在Canvas中生成多个可移动的点,然后依 ...
- 【重点突破】——使用Canvas进行绘图图像
一.引言 本文主要是canvas绘图中绘制图像的部分,做了几个练习,综合起来,复习canvas绘图以及定时器的使用. 二.canvas绘制小飞机在指定位置 <!DOCTYPE html> ...
- HDU 3466 01背包变形
给出物品数量N和总钱数M 对于N个物品.每一个物品有其花费p[i], 特殊值q[i],价值v[i] q[i] 表示当手中剩余的钱数大于q[i]时,才干够买这个物品 首先对N个物品进行 q-p的排序,表 ...
- 【MVC2】发布到IIS7.5上后Session为null
MVC2代码「Session.IsNewSession」在VS中可以正常执行,发布到IIS7.5上之后Session为null导致出错. if (Session.IsNewSession) { ... ...
- Vue2.0 :key作用
转自:https://www.cnblogs.com/zhumingzhenhao/p/7688336.html 为了给 Vue 一个提示,以便它能跟踪每个节点的身份,从而重用和重新排序现有元素,你需 ...
- 【Excle数据透视表】如何移动数据透视表的位置
数据透视表创建完成了,现在需要将它移动到D5位置,如何移动呢? 解决办法 通过"移动数据透视表"功能实现数据透视表的位置移动 步骤1 单击数据透视表任意单元格→数据透视表工具→分析 ...