第一次接触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 Base64编码和解码,实现URL参数传递。
Sep 18 Javascript
jquery+ashx无刷新GridView数据显示插件(实现分页、排序、过滤功能)
Apr 25 Javascript
JavaScript实现生成GUID(全局统一标识符)
Sep 05 Javascript
JavaScript 性能优化小结
Oct 12 Javascript
JS更改select内option属性的方法
Oct 14 Javascript
Angularjs验证用户输入的字符串是否为日期时间
Jun 01 Javascript
JavaScript常用数学函数用法示例
May 14 Javascript
vue中element 上传功能的实现思路
Jul 06 Javascript
详解vue通过NGINX部署在子目录或者二级目录实践
Sep 03 Javascript
在 Vue 中编写 SVG 图标组件的方法
Feb 24 Javascript
vue 组件间的通信之子组件向父组件传值的方式
Jul 29 Javascript
Vue封装Axios请求和拦截器的步骤
Sep 16 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 字符串分割和比较
2009/10/06 PHP
php实现refresh刷新页面批量导入数据的方法
2014/12/23 PHP
jquery 插件开发方法小结
2009/10/23 Javascript
前端开发部分总结[兼容性、DOM操作、跨域等](持续更新)
2010/03/04 Javascript
jQuery实现点击图片翻页展示效果的方法
2015/02/16 Javascript
纯javascript移动优先的幻灯片效果
2015/11/02 Javascript
JavaScript实现斗地主游戏的思路
2016/02/29 Javascript
js判断出两个字符串最大子串的函数实现方法
2016/11/01 Javascript
Angular工具方法学习
2016/12/26 Javascript
简单的JS控制button颜色随点击更改的实现方法
2017/04/17 Javascript
canvas+gif.js打造自己的数字雨头像的示例代码
2017/10/26 Javascript
vue-router 实现导航守卫(路由卫士)的实例代码
2018/09/02 Javascript
使用jquery的cookie实现登录页记住用户名和密码的方法
2019/03/13 jQuery
JS正则表达式封装与使用操作示例
2019/05/15 Javascript
React 条件渲染最佳实践小结(7种)
2020/09/27 Javascript
vue+iview使用树形控件的具体使用
2020/11/02 Javascript
Python中用Ctrl+C终止多线程程序的问题解决
2013/03/30 Python
python实现查询苹果手机维修进度
2015/03/16 Python
Python代码调试的几种方法总结
2015/04/15 Python
Python如何避免文件同名产生覆盖
2020/06/09 Python
解决redis与Python交互取出来的是bytes类型的问题
2020/07/16 Python
让你相见恨晚的十个Python骚操作
2020/11/18 Python
微信小程序“圣诞帽”的实现思路详解
2017/12/28 HTML / CSS
Snapfish英国:在线照片打印和个性化照片礼品
2017/01/13 全球购物
世界上最大的字体市场:MyFonts
2020/01/10 全球购物
奢华时尚的创新平台:Baltini
2020/10/03 全球购物
普通PHP程序员笔试题
2016/01/01 面试题
回门宴新郎答谢词
2014/01/12 职场文书
酒店保安员岗位职责
2014/01/31 职场文书
2014年党员创先争优承诺书
2014/05/29 职场文书
上班迟到检讨书范文300字
2014/11/02 职场文书
北京故宫的导游词
2015/01/31 职场文书
项目经理岗位职责
2015/01/31 职场文书
辩论赛主持人开场白
2015/05/29 职场文书
Python控制台输出俄罗斯方块的方法实例
2021/04/17 Python
详解python网络进程
2021/06/15 Python