随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签来导入一个个的js文件这种方式已经不能满足现在互联网开发模式,我们需要团队协作、模块复用、单元测试等等一系列复杂的需求

RequireJS是一个非常小巧的JavaScript模块载入框架,是AMD规范最好的实现者之一

 <!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="a.js"></script>
</head>
<body>
<span>body</span>
</body>
</html>

a.js:

 (function(){
function fun1(){
alert("it works");
} fun1();
})()

使用了块作用域来申明function防止污染全局变量,本质还是一样的,当运行上面两种例子时不知道你是否注意到,alert执行的时候,html内容是一片空白的,即<span>body</span>并未被显示,当点击确定后,才出现,这就是JS阻塞浏览器渲染导致的结果。

requirejs写法

 <!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="../js/require.js"></script>
<script>
require(['t']);
</script>
</head>
<body>
_requireJS
</body>
</html>

t.js:

 define(function(){
function fun1(){
alert("it works");
}
fun1();
});

览器提示了"it works",说明运行正确,但是有一点不一样,这次浏览器并不是一片空白,body已经出现在页面中,目前为止可以知道requirejs具有如下优点:

  1. 防止js加载阻塞页面渲染
  2. 使用程序调用的方式加载js,防出现如下丑陋的场景
 <script type="text/javascript" src="a.js"></script>
<script type="text/javascript" src="b.js"></script>
<script type="text/javascript" src="c.js"></script>
<script type="text/javascript" src="d.js"></script>
<script type="text/javascript" src="e.js"></script>
<script type="text/javascript" src="f.js"></script>
<script type="text/javascript" src="g.js"></script>
<script type="text/javascript" src="h.js"></script>
<script type="text/javascript" src="i.js"></script>
<script type="text/javascript" src="j.js"></script>

本文来源:http://www.runoob.com/w3cnote/requirejs-tutorial-1.html

最新文章

  1. Java--对象池化技术 org.apache.commons.pool2.ObjectPool
  2. 【leetcode】N-Queens
  3. Matlab Delete Row or Col 删除矩阵的行或列
  4. Magento - Rewrite机制一窥
  5. html 如何获取表格中所选行的一行数据,并赋值到对应的TEXT里面?
  6. JavaWeb学习总结(十五)--过滤器的应用
  7. Java排序
  8. 使用struts dojo ajax源码案例
  9. SQLite使用教程4 附加数据库
  10. modelsim遇到的问题(更新)
  11. HDU2952:Counting Sheep(DFS)
  12. js将字符串转化成函数:eval(logOutCallbackFun+&quot;()&quot;);
  13. POJ-2996 Help Me with the Game---模拟棋子
  14. Gradle学习之构建java与web项目
  15. Android DrawerLayout侧滑菜单
  16. uiautomatorviewer 优化定位符生成,支持生成Java,Python自动化代码
  17. for里的上一个/下一个下标的安全写法
  18. 初学者的分布式Python爬虫教程
  19. 课程一(Neural Networks and Deep Learning),第一周(Introduction to Deep Learning)—— 0、学习目标
  20. pg_stat_statements源代码分析

热门文章

  1. Java-马士兵设计模式学习笔记-工厂模式-抽象工厂模式
  2. R: 用 R 查看、管理文件(夹)
  3. Java数据结构与算法分析-第一章(引论)-Java中的范型&lt;T,E&gt;构件
  4. vs2010 怎样设置文本编辑窗口和解决方案资源管理器同步?
  5. rf常用关键字
  6. leetcode mergeKsortedlink
  7. 免费证书申请——Let&#39;s Encrypt的申请与应用(IIS,Tomcat)
  8. 《OD面试》之多线程高并发
  9. tomcat8性能优化
  10. C语言数据结构-队列的实现-初始化、销毁、清空、长度、队列头元素、插入、删除、显示操作