第一次接触JS require.js模块化工具


Posted in Javascript onApril 17, 2016

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

第一次接触JS require.js模块化工具

RequireJS是一个非常小巧的JavaScript模块载入框架,是AMD规范最好的实现者之一。最新版本的RequireJS压缩后只有14K,堪称非常轻量。它还同时可以和其他的框架协同工作,使用RequireJS必将使您的前端代码质量得以提升。

requirejs能带来什么好处

官方对requirejs的描述:

RequireJS is a JavaScript file and module loader. It is optimized for in-browser use, but it can be used in other JavaScript environments, like Rhino and Node. Using a modular script loader like RequireJS will improve the speed and quality of your code.

大致意思:

在浏览器中可以作为js文件的模块加载器,也可以用在Node和Rhino环境,balabala...。这段话描述了requirejs的基本功能"模块化加载",什么是模块化加载?我们要从之后的篇幅中一一解释

先来看一段常见的场景,通过示例讲解如何运用requirejs

正常编写方式
index.html:

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

a.js:

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

可能你更喜欢这样写

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

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

requirejs写法

当然首先要到requirejs的网站去下载js -> requirejs.rog
index.html:

<!DOCTYPE html>
<html>
 <head>
  <script type="text/javascript" src="require.js"></script>
  <script type="text/javascript">
   require(["a"]);
  </script>
 </head>
 <body>
  <span>body</span>
 </body>
</html>

a.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>

以上就是本文的全部内容,希望对大家认识require.js模块化工具有所帮助。

Javascript 相关文章推荐
javascript判断单选框或复选框是否选中方法集锦
Apr 04 Javascript
jquery1.4.2 for Visual studio 2010 模板文件
Jul 14 Javascript
JQuery each打印JS对象的方法
Nov 13 Javascript
js+css实现超简洁的二级下拉菜单效果代码
Sep 07 Javascript
每天一篇javascript学习小结(Function对象)
Nov 16 Javascript
JavaScript+canvas实现七色板效果实例
Feb 18 Javascript
JavaScript字符串常用的方法
Mar 10 Javascript
AngularJS 模块化详解及实例代码
Sep 14 Javascript
JavaScript轻松创建级联函数的方法示例
Feb 10 Javascript
关于AngularJS中ng-repeat不更新视图的解决方法
Sep 30 Javascript
Vue.js子组件向父组件通信的方法实例代码详解
Dec 10 Javascript
vue移动端写的拖拽功能示例代码
Sep 09 Javascript
jqGrid 学习笔记整理——进阶篇(一 )
Apr 17 #Javascript
JS组件Bootstrap dropdown组件扩展hover事件
Apr 17 #Javascript
理解javascript对象继承
Apr 17 #Javascript
node.js连接mongoDB数据库 快速搭建自己的web服务
Apr 17 #Javascript
js如何准确获取当前页面url网址信息
Sep 13 #Javascript
基于javascript实现图片切换效果
Apr 17 #Javascript
非常棒的jQuery图片轮播效果
Apr 17 #Javascript
You might like
PHP array_key_exists检查键名或索引是否存在于数组中的实现方法
2016/06/13 PHP
深入理解PHP JSON数组与对象
2016/07/19 PHP
php实现当前页面点击下载文件的简单方法
2016/09/22 PHP
php正则修正符用法实例详解
2016/12/29 PHP
PHP钩子与简单分发方式实例分析
2017/09/04 PHP
javascript实现动态CSS换肤技术的脚本
2007/06/29 Javascript
javascript qq右下角滑出窗口 sheyMsg
2010/03/21 Javascript
用Javascript实现Windows任务管理器的代码
2012/03/27 Javascript
javascript页面加载完执行事件代码
2014/02/11 Javascript
javascript中声明函数的方法及调用函数的返回值
2014/07/22 Javascript
利用a标签自动解析URL分析网址实例
2014/10/20 Javascript
JavaScript中的return语句简单介绍
2015/12/07 Javascript
Angularjs单选改为多选的开发过程及问题解析
2017/02/17 Javascript
Bootstrap 实现表格样式、表单布局的实例代码
2018/12/09 Javascript
JavaScript工具库之Lodash详解
2019/06/15 Javascript
安装多版本Vue-CLI的实现方法
2020/03/24 Javascript
JavaScript中while循环的基础使用教程
2020/08/11 Javascript
python 中文字符串的处理实现代码
2009/10/25 Python
Python实现简单过滤文本段的方法
2017/05/24 Python
Python简单生成随机姓名的方法示例
2017/12/27 Python
python实现电子产品商店
2019/02/26 Python
python实现AES加密和解密
2019/03/27 Python
解决Django连接db遇到的问题
2019/08/29 Python
Python3实现二叉树的最大深度
2019/09/30 Python
Pytorch中index_select() 函数的实现理解
2019/11/19 Python
Python常用模块函数代码汇总解析
2020/08/31 Python
pyqt5实现井字棋的示例代码
2020/12/07 Python
美国和加拿大房车出售在线分类广告:RVT.com
2018/04/23 全球购物
Bailey帽子官方商店:Bailey Hats
2018/09/25 全球购物
仓库门卫岗位职责
2013/12/22 职场文书
大学学习生活感言
2014/01/18 职场文书
《爱如茉莉》教后反思
2014/04/12 职场文书
《果园机器人》教学反思
2014/04/13 职场文书
2014向国旗敬礼网上签名活动总结
2014/09/27 职场文书
趣味运动会新闻稿
2015/07/17 职场文书
十大最强飞行系宝可梦,BUG燕上榜,第二是飞行系王者
2022/03/18 日漫