第一次接触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 中介者模式实例
Dec 16 Javascript
jQuery手机浏览器中拖拽动作的艰难性分析
Feb 04 Javascript
jQuery页面加载初始化的3种方法(推荐)
Jun 02 Javascript
用jQuery向div中添加Html文本内容的简单实现
Jul 13 Javascript
JS只能输入正整数的简单实例
Oct 07 Javascript
jQuery的Read()方法代替原生JS详解
Nov 08 Javascript
微信小程序组件 contact-button(客服会话按钮)详解及实例代码
Jan 10 Javascript
解决Mac安装thrift因bison报错的问题
May 17 Javascript
Vue引用Swiper4插件无法重写分页器样式的解决方法
Sep 27 Javascript
微信小程序实现登录注册tab切换效果
Dec 29 Javascript
Vue.js自定义指令学习使用详解
Oct 19 Javascript
Vue+webpack实现懒加载过程解析
Feb 17 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中strcmp()和strcasecmp()函数字符串比较用法分析
2016/01/07 PHP
thinkPHP多域名情况下使用memcache方式共享session数据的实现方法
2016/07/21 PHP
PHP实现统计代码行数小工具
2019/09/19 PHP
复制本贴标题和地址的js代码
2008/07/01 Javascript
JQuery将文本转化成JSON对象需要注意的问题
2011/05/09 Javascript
css transform 3D幻灯片特效实现步骤解读
2013/03/27 Javascript
图片翻转效果具体实现代码
2014/01/09 Javascript
jquery判断至少有一个checkbox被选中的方法
2015/06/05 Javascript
JavaScript实现算术平方根算法-代码超简单
2015/09/11 Javascript
javascript解决小数的加减乘除精度丢失的方案
2016/05/31 Javascript
jQuery过滤选择器用法示例
2016/09/12 Javascript
node 使用 async 控制并发的方法
2018/05/07 Javascript
Vue的watch和computed方法的使用及区别介绍
2018/09/06 Javascript
vue3.0 CLI - 2.2 - 组件 home.vue 的初步改造
2018/09/14 Javascript
Layui实现数据表格中鼠标悬浮图片放大效果,离开时恢复原图的方法
2019/09/11 Javascript
js实现滚动条自动滚动
2020/12/13 Javascript
[54:06]OG vs TNC 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
python中的sort方法使用详解
2014/07/25 Python
python Spyder界面无法打开的解决方法
2018/04/27 Python
Python获取时间戳代码实例
2019/09/24 Python
将数据集制作成VOC数据集格式的实例
2020/02/17 Python
Python基于requests实现模拟上传文件
2020/04/21 Python
解决django 向mysql中写入中文字符出错的问题
2020/05/18 Python
pycharm 实现本地写代码,服务器运行的操作
2020/06/08 Python
Django如何批量创建Model
2020/09/01 Python
CSS3 制作绽放的莲花采用效果叠加实现
2013/01/31 HTML / CSS
校园活动策划书范文
2014/01/10 职场文书
《奇妙的国际互联网》 教学反思
2014/02/25 职场文书
《忆江南》教学反思
2014/04/07 职场文书
股权转让协议书范本
2014/04/12 职场文书
2014年餐厅服务员工作总结
2014/11/18 职场文书
大班上学期个人总结
2015/02/13 职场文书
2015年安全工作总结范文
2015/04/02 职场文书
离婚起诉状范本
2015/05/19 职场文书
挂职锻炼工作总结2015
2015/05/28 职场文书
农贸批发市场管理制度
2015/08/07 职场文书