第一次接触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 打地鼠游戏代码说明
Oct 12 Javascript
JQuery拖拽元素改变大小尺寸实现代码
Dec 10 Javascript
JavaScript对象之深度克隆介绍
Dec 08 Javascript
jQuery插件zoom实现图片全屏放大弹出层特效
Apr 15 Javascript
整理Javascript基础入门学习笔记
Nov 29 Javascript
学习使用jquery iScroll.js移动端滚动条插件
Mar 24 Javascript
深入理解jQuery 事件处理
Jun 14 Javascript
axios学习教程全攻略
Mar 26 Javascript
MUI实现上拉加载和下拉刷新效果
Jun 30 Javascript
vue源码中的检测方法的实现
Sep 26 Javascript
解决vue scoped scss 无效的问题
Sep 04 Javascript
JS相册图片抖动放大展示效果的示例代码
Jan 29 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
星际争霸 Starcraft 秘技补丁
2020/03/14 星际争霸
自己动手,丰衣足食 - 短波框形天线制作
2021/03/01 无线电
为了这两部电子管收音机,买了6套全新电子管和10粒刻度盘灯泡
2021/03/02 无线电
php目录管理函数小结
2008/09/10 PHP
PHP使用反射机制实现查找类和方法的所在位置
2016/04/22 PHP
LAMP环境使用Composer安装Laravel的方法
2017/03/25 PHP
javascript 动态数据下的锚点错位问题解决方法
2008/12/24 Javascript
利用JS自动打开页面上链接的实现代码
2011/09/25 Javascript
JS过滤url参数特殊字符的实现方法
2013/12/24 Javascript
Javascript无参数和有参数类继承问题解决方法
2015/03/02 Javascript
三个js循环的关键字示例(for与while)
2016/02/16 Javascript
基于gulp合并压缩Seajs模块的方式说明
2016/06/14 Javascript
Angularjs CURD 详解及实例代码
2016/09/14 Javascript
简单实现js无缝滚动效果
2017/02/05 Javascript
JavaScript中Promise的使用详解
2017/02/26 Javascript
动态创建Angular组件实现popup弹窗功能
2017/09/15 Javascript
jquery ajaxfileuplod 上传文件 essyui laoding 效果【防止重复上传文件】
2018/05/26 jQuery
jQuery创建及操作xml格式数据示例
2018/05/26 jQuery
vue实现将一个数组内的相同数据进行合并
2019/11/07 Javascript
Vue执行方法,方法获取data值,设置data值,方法传值操作
2020/08/05 Javascript
Python实现合并字典的方法
2015/07/07 Python
python仿evething的文件搜索器实例代码
2019/05/13 Python
Python中的相关分析correlation analysis的实现
2019/08/29 Python
基于python检查SSL证书到期情况代码实例
2020/04/04 Python
TensorFlow打印输出tensor的值
2020/04/19 Python
解决pymysql cursor.fetchall() 获取不到数据的问题
2020/05/15 Python
Python如何使用27行代码绘制星星图
2020/07/20 Python
详解Django中views数据查询使用locals()函数进行优化
2020/08/24 Python
英文版网络工程师求职信
2013/10/28 职场文书
文体活动总结范文
2014/05/05 职场文书
大学生感恩父母演讲稿
2014/08/28 职场文书
小学竞选班长演讲稿
2014/09/09 职场文书
离婚协议书格式
2014/11/21 职场文书
道歉信范文
2015/05/12 职场文书
python自动化之如何利用allure生成测试报告
2021/05/02 Python
详解Redis的三种常用的缓存读写策略步骤
2022/05/06 Redis