【原】requirejs学习笔记
随着JS越来越庞大,已经不仅仅是以前复制粘贴做特效的时代了,JS越来越偏向于业务逻辑与应用。JS在web开发中占有越来越重要的地位。
由于JS代码庞大,文件数目多,传统的使用<script src=""></script>会带来很多性能的问题,因此requirejs可以为我们提供解决思路,它有以下的功能:
1、声明不同js文件之间的依赖
2、可以按需、并行、延时载入js库
3、可以让我们的代码以模块化的方式组织
下面进行实战:
文档结构是这样的
.js/app/config.js
.js/require.js
.js/app/hello1.js
.js/app/hello2.js
.js/app/hello3.js
index.html
在index.html中引入requirejs
<script src="js/require.js" data-main="js/app/config.js"></script>
其中,data-main指定主要的配置文件. config.js如下:
require.config({
//默认情况下模块所在目录为js/app
baseUrl: 'js/app',
//这里设置的路径是相对与baseUrl的,不要包含.js,否则会报错
paths: {
h1: 'hello1',
h2:'hello2',
h3:'hello3'
}
});
// 开始逻辑.
requirejs(['h1', 'h2', 'h3'],
function (h1, h2, h3) {
//这里是引入那三个js之后的回调函数
h1.hello(); //I am hello1
h2.hello(); //I am hello2
h3.hello(); //I am hello3
});
hello1.js
define([], function() {
return {
hello: function() {
console.log("I am hello1");
}
}
});
hello2.js
define([], function() {
return {
hello: function() {
console.log("I am hello2");
}
}
});
hello3.js
define([], function() {
return {
hello: function() {
console.log("I am hello3");
}
}
});
require加载文件时,会自动加上.js后缀。当某些模块依赖其他模块时,可以通过define([xxx],function(xxx){yyy});的方式添加依赖关系,
require会在异步加载后,自动调整次序。
shim
当有些js不是AMD规范的时候,或者我有一个public.js需要依赖于jquery时,config.js可以这样写
代码如下:
requirejs.config({
baseUrl: 'js/app',
paths:{
"jquery":"jquery-1.11.2.min",
"public":"public",
},
// 这个配置是你在引入依赖的时候的包名,比如一些不是AMD规范的插件
shim: {
'public': {
deps: ['jquery'],
//exporets 就是被外界访问的接口,比如jquery的$
exports: 'public'
},
}
});
require(['public'], function (p) {
// somecode
});
使用中遇到的问题以及解决方法:
当我require.js没有用在单页面的时候,我遇到了这样一个问题:
比如我1.html需要有另外的一些单独函数,而其他页面是不需要的,并且我希望在加载完config.js之后再执行我那个单独的函数,那要怎么做呢。
如果直接写在config.js里面的require后的回调函数那里,那么要单独分开每一个config.js,这样就没意思了。一位博友给出的答案是
index.html
<script src="js/require.js" data-main="js/app/config.js" require-module="js/app/other.js"></script> //加个require-module属性,后面加上你需要单独引入的js
config.js 里面这样
require.config({
baseUrl: 'js/app',
paths:{
"jquery":"jquery-1.11.2.min",
"public":"public",
},
shim: {
'public': {deps: ['jquery'],exports:'public'}
}
});
require(['jquery','public'], function($,p){
//改变的是这里
var scripts = document.getElementsByTagName("script");
for (var i = 0; i < scripts.length; i++) {
// 获取页面所需加载模块入口名称,需要单独引入的js写在 script里面 require-module这个属性这里
var module = scripts[i].getAttribute("require-module");
if (module != undefined && module != "") {
require([module ]);
break;
}
}
});
这样的话,你就可以在确保config里面的js加载完毕后,再加载你自己的js
暂时先写到这里先,有错误的话欢迎指出
【原】requirejs学习笔记的更多相关文章
- RequireJS学习笔记
前言 进入移动前端是很不错的选择,这块也是我希望的道路,但是不熟悉啊... 现在项目用的是require+backbone,整个框架被封装了一次,今天看了代码搞不清楚,觉得应该先从源头抓起,所以再看看 ...
- Requirejs学习笔记(一)
中文api 和 英文api网上都有的我就不翻译了,我的学习方法是先看英文api,然后看不懂的就比对中文api看一遍. requirejs可以帮助js代码模块化开发,模块化意味了解决了代码凌乱的问题,方 ...
- RequireJS学习笔记(转)
前言 进入移动前端是很不错的选择,这块也是我希望的道路,但是不熟悉啊... 现在项目用的是require+backbone,整个框架被封装了一次,今天看了代码搞不清楚,觉得应该先从源头抓起,所以再看看 ...
- RequireJs学习笔记之data-main Entry Point
You will typically use a data-main script to set configuration options and then load the first appli ...
- RequireJs学习笔记之Define a Module
简单的键值对定义define({ color: "black", size: "unisize"}); 如果一个模块没有任何依赖,又需要做用一个函数 ...
- Matplotlib学习笔记(二)
原 Matplotlib学习笔记 参考:Python数据科学入门教程 Python3.6.1 jupyter notebook .caret, .dropup > .btn > .car ...
- Matplotlib学习笔记(一)
原 matplotlib学习笔记 参考:Python数据科学入门教程 Python3.6.1 jupyter notebook .caret, .dropup > .btn > .ca ...
- 【原】Learning Spark (Python版) 学习笔记(三)----工作原理、调优与Spark SQL
周末的任务是更新Learning Spark系列第三篇,以为自己写不完了,但为了改正拖延症,还是得完成给自己定的任务啊 = =.这三章主要讲Spark的运行过程(本地+集群),性能调优以及Spark ...
- 并发编程学习笔记(4)----jdk5中提供的原子类及Lock使用及原理
(1)jdk中原子类的使用: jdk5中提供了很多原子类,它会使变量的操作变成原子性的. 原子性:原子性指的是一个操作是不可中断的,即使是在多个线程一起操作的情况下,一个操作一旦开始,就不会被其他线程 ...
随机推荐
- EmitMapper的使用
1.普通的映射. public class UserInfo { public int id { get; set; } public string name { get; set; } public ...
- linux 定时执行scrapy命令
解决方案: 1.以管理员方式执行命令添加计划 sudo crontab -e 添加: 1 0 * * * sh /home/ubuntu/CRON/cron.sh 2. 重启cron服务 sudo s ...
- Ubuntu 完全卸载Apache2
安装时候使用的一键安装,很简单 apt-get install apache2 这两天想配置一个lighttpd,但是一直不能成功,今天在公司用虚拟机里面的Ubuntu 配置lighttpd成功了,怀 ...
- Redis集群(六):集群常用命令及说明
一.本文目的 介绍集群的基本情况及常用命令 二.集群的特点 3.集群优缺点 三.集群客户端命令(redis-cli -c -p port) 集群cluster info ...
- 【BZOJ 1069】【SCOI 2007】最大土地面积 凸包+旋转卡壳
因为凸壳上对踵点的单调性所以旋转卡壳线性绕一圈就可以啦啦啦--- 先求凸包,然后旋转卡壳记录$sum1$和$sum2$,最后统计答案就可以了 #include<cmath> #includ ...
- 【BZOJ 2733】【HNOI 2012】永无乡 Splay启发式合并
启发式合并而已啦,, 调试时发现的错误点:insert后没有splay,把要拆开的树的点插入另一个树时没有把ch[2]和fa设为null,找第k大时没有先减k,,, 都是常犯的错误,比赛时再这么粗心就 ...
- kkt
- EPUB书籍阅读器插件分享
本文主要分享EPUB文件的打开方式, 包括如何使用火狐浏览器打开epub, 如何使用chrome打开epub, 如何使用IE浏览器打开epub文件: 1:使用火狐打开epub文件 如果有安装火狐浏览器 ...
- 100726A
迭代深搜,从最深的地方搜,然后一个数被搜过了,标记用过,以后不再访问 #include<iostream> #include<cstring> #include<map& ...
- C# 获取当前月第一天和最后一天
废话不多说,直接上代码 //先获取当前时间 DateTime now = DateTime.Now; //获取当前月的第一天 DateTime d1 = new DateTime(now.Year, ...