第一次接触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写了一个清除“logo1_.exe”的杀毒工具(可扫描目录)
Feb 09 Javascript
jquery图片延迟加载 前端开发技能必备系列
Jun 18 Javascript
Jquery chosen动态设置值实例介绍
Aug 08 Javascript
实现js保留小数点后N位的代码
Nov 13 Javascript
jquery实现标题字体变换的滑动门菜单效果
Sep 07 Javascript
JS实现微信里判断页面是否被分享成功的方法
Jun 06 Javascript
Makefile/cmake/node-gyp中区分判断不同平台的方法
Dec 18 Javascript
详解小程序如何避免多次点击,重复触发事件
Apr 08 Javascript
详解vue-cli3开发Chrome插件实践
May 29 Javascript
如何测量vue应用运行时的性能
Jun 21 Javascript
JavaScript复制变量三种方法实例详解
Jan 09 Javascript
vue+iview分页组件的封装
Nov 17 Vue.js
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的宝库目录--PEAR
2006/10/09 PHP
php获取301跳转URL简单实例
2013/12/16 PHP
Laravel中正确地返回HTTP状态码方法示例
2019/09/10 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
基于jquery的一行代码轻松实现拖动效果
2010/12/28 Javascript
jquery+ajax每秒向后台发送请求数据然后返回页面的代码
2011/01/17 Javascript
js网页侧边随页面滚动广告效果实现
2011/04/14 Javascript
js去字符串前后空格5种实现方法及比较
2013/04/03 Javascript
Extjs4 GridPanel的主要配置参数详细介绍
2013/04/18 Javascript
javascript操作字符串的原生方法
2014/12/22 Javascript
jQuery+HTML5+CSS3制作支持响应式布局时间轴插件
2016/08/10 Javascript
JQuery实现定时刷新功能代码
2017/05/09 jQuery
vue 组件使用中的一些细节点
2018/04/25 Javascript
nodejs读取本地中文json文件出现乱码解决方法
2018/10/10 NodeJs
使用vue2实现带地区编号和名称的省市县三级联动效果
2018/11/05 Javascript
详解VScode编辑器vue环境搭建所遇问题解决方案
2019/04/26 Javascript
微信小程序开发注意指南和优化实践(小结)
2019/06/21 Javascript
Layui选项卡制作历史浏览记录的方法
2019/09/28 Javascript
javascript的delete运算符知识点总结
2019/11/19 Javascript
基于vue-cli3+typescript的tsx开发模板搭建过程分享
2020/02/28 Javascript
Vue + Scss 动态切换主题颜色实现换肤的示例代码
2020/04/27 Javascript
快速解决element的autofocus失效问题
2020/09/08 Javascript
Python的Flask框架中@app.route的用法教程
2015/03/31 Python
python安装教程 Pycharm安装详细教程
2017/05/02 Python
Python中数组,列表:冒号的灵活用法介绍(np数组,列表倒序)
2018/04/18 Python
python实现微信自动回复及批量添加好友功能
2019/07/03 Python
Python2与Python3的区别点整理
2019/12/12 Python
Python post请求实现代码实例
2020/02/28 Python
python实现文字版扫雷
2020/04/24 Python
Django mysqlclient安装和使用详解
2020/09/17 Python
英国品牌男装折扣网站:Brown Bag
2018/03/08 全球购物
庆祝国庆节标语
2014/10/09 职场文书
银行职员工作失误检讨书
2014/10/14 职场文书
幼儿园个人师德总结
2015/02/06 职场文书
谢师宴家长致辞
2015/07/27 职场文书
2016年小学教师政治学习心得体会
2016/01/23 职场文书