javascript模块化编程库require.js的用法

随着javascript的兴起,越来越多的公司开始将JS模块化,以增加开发的效率和减少重复编写代码的。更是为了能更加容易的维护日后的代码,因为现在的随着人们对交互效果的越来越强烈的需求,我们的JS代码也从以前的几十行代码,慢慢的发展到了现在的几百甚至上千过万,但是要怎么才能把这些代码很好的整合起来呢?
面向对象的编程方法应该是目前最为流行的编程方式,将所有代码都模块化,不仅有利于增加我们开发效率,而且还使我们代码更容易维护。今天就推荐一个目前比较流行的require.js库,用来编写javascript模块化倒是不错的一个选择,以下是我的一些学习总结,希望对大家学习这个库有点帮助
require.js主要特色功能
我们现在写JS一般一个站点最少都会有两到三个JS文件,多则七八个JS文件都很正常。看下淘宝的首页加载的JS文件数量:
:
是不是非常的惊人,巨多的文件,面对这样的多的JS文件,说实在的很头疼,而且许多JS文件是有依赖性的,例如:
<script type="text/javascript" src="1.js"></script>
<script type="text/javascript" src="2.js"></script>
<script type="text/javascript" src="3.js"></script>
像上面这样的JS文件,2.js文件要依赖与1.js文件,3.js又要依赖前面两个js文件,他们之间的先后顺序还不能出现错误,否则JS就会报错。像上面这样一个页面需要如此多的JS文件,对我们使用他们的功能时其实是种负担,因为调用一个功能的时候我们需要加载多个JS文件,而且调用JS的顺序必须按照顺序。除了这个问题,我还不知道,我们调用的这些JS会不会跟其他JS发生冲突,这就更加坑爹了
但是上面这些问题,require.js可以很好的解决:
实现js文件的异步加载,避免网页失去响应;
管理模块之间的依赖性,便于代码的编写和维护。
导入require.js文件方法
首先大家可以到require.js的官网去下载最新的文件包。下载完以后我们把require.js放到我们的JS文件目录下,然后把它加载到页面上:
- <script src="js/require.js" defer async="true" ></script>
我们上面给这个JS加了两个额外的属性:defer和async,这两个属性主要是为了让浏览器能在页面元素全部加载完以后再加载JS,我称这个为异步加载JS,这种方法可以避免因为加载JS时页面卡住,出现假死的状态,所以我们让先让页面呈现出来,然后在加载JS,相当于平常我们把JS放到页面底部原理差不多。上面defer属性是因为IE不支持async,所以加上的。
加载require.js以后,下一步就要加载我们自己的JS文件了。假如我们自己的代码文件是main.js,也放在JS目录下面。那么,只需要写成下面这样就行了:
- <script src="js/require.js" data-main="js/main"></script>
data-main属性的作用是,指定网页程序的主模块。在上例中,就是js目录下面的main.js,这个文件会第一个被require.js加载。由于require.js默认的文件后缀名是js,所以可以把main.js简写成main。
require.js配置文件方法
我们的JS文件不单单是只要main.js这个文件,我们还需要加载其他文件,这时候我们只需要在main.js这个文件里面编写好你需要另外加载的JS文件,这时我们要用他的require()函数,这个函数有两个参数:第一个参数是一个数组,表示所依赖的模块;第二个参数是一个回调函数,当前面指定的模块都加载成功后,我们将调用它;
- require(['moduleA', 'moduleB', 'moduleC'], function (moduleA, moduleB, moduleC){
- //回调成功后的操作
- });
上面模块会按照你填写的先后顺序异步加载到页面中:A,B,C。加载成功后才会执行操作代码。这样就可以防止页面出现假死的状况了。
可能有很多的人JS都是依赖一些框架来写的,这时候我们就需要加载例如jquery等库进来的时候,我们就可以这样写:
- requirejs(['jquery', 'canvas', 'app/sub'],
- function ($,canvas,sub) {
- //jQuery, canvas and the app/sub module are all
- //loaded and can be used here now.
- });
看上面的代码,jquery他会自动去寻找jquery.js文件,所以你想加载成功你的jquery你就需要将他命名为jquery.js这样才行。但是如果希望你的jquery文件可以带版本号,require.js也可以满足你的需求,它提供了require.config()的函数,可以让我们自定义一些路径,文件名称。我们可以这样写代码:
- require.config({
- paths: {
- "jquery": "jquery-1.8.3.min",
- }
- });
请记住一点,我们的文件名不需要加.js后缀,否则require.js会找不到文件的。
看到上面的代码,有些人可能还会问,如果我的JS文件不是跟main.js在同一个目录的时候怎么办?方法和上面的差不多,直接改目录,假设我们jquery放在JS文件夹下面的libs目录下面时,我们可以这样写:
- require.config({
- paths: {
- jquery: 'libs/jquery-1.8.3.min'
- }
- });
还可以用另外一种写法,直接改变基目录:
- requirejs.config({
- baseUrl: 'js/lib',
- paths: {
- jquery: 'jquery-1.8.3.min'
- }
- });
require.js模块化编程方法
require.js的所有模块必须采用特定的define()函数的来定义。如果一个模块不依赖其他模块,那么就可以直接定义在define()函数中。例如:
- //main.js
- define({
- color: "black",
- size: "unisize"
- });
调用上面方法:
- //main.js
- require(['main'], function (main){
- console.log(main.color); //black
- console.log(main.size); //unisize
- });
如果我们要编写函数,我们可以这样写:
- define(function (){
- var Total = function (x,y){
- return x+y;
- };
- return {
- total: Total
- };
- });
调用上面的代码:
- //main.js
- require(['main'], function (main){
- console.log(wnf.total(5,10));
- });
require.js加载的模块,采用AMD规范。也就是说,模块必须按照AMD的规定来写。具体来说,就是模块必须采用特定的define()函数来定义。如果一个模块不依赖其他模块,那么可以直接定义在define()函数之中
如果这个模块还依赖其他模块,那么define()函数的第一个参数,必须是一个数组,指明该模块的依赖性。
- define(['jquery'], function(){
- var foo = function(){
- $("body").click(function(){
- alert("jquery");
- });
- }
- return {
- foo : foo
- };
- });
然后我们调用上面的方法:
- //main.js
- require(['main'], function (main){
- main.foo();//jquery
- });
上面是我的学习笔记,看完你应该能对require.js有些了解,如果想更详细的了解这个库的功能,建议大家可以到require.js官网去进行深入了解学习。
转载请注明来自 520UED http://www.520ued.com/article/538830e8b992a7c43f5c204d
javascript模块化编程库require.js的用法的更多相关文章
- Javascript模块化编程:require.js的用法
摘自:http://blog.jobbole.com/30046/ 这个系列的第一部分和第二部分,介绍了Javascript模块原型和理论概念,今天介绍如何将它们用于实战. 我采用的是一个非常流行的库 ...
- Javascript模块化编程(三)require.js的用法及功能介绍
这个系列的第一部分和第二部分,介绍了Javascript模块原型和理论概念,今天介绍如何将它们用于实战.我采用的是一个非常流行的库require.js感兴趣的朋友可以了解下啊 我采用的是一个非常流行的 ...
- Javascript模块化编程-require.js
转自:https://www.cnblogs.com/digdeep/p/4607131.html Javascript模块化编程(一):模块的写法 随着网站逐渐变成"互联网应用程序&quo ...
- JavaScript模块化编程之require.js与sea.js
为什么要模块化:当今,网站以不再是一个简单的页面,JavaScript也不再是做一些简单的脚本验证,随着WEB.20时代到来,前端工程师面临的必将是越来越庞大的JavaScript代码,越来越复杂的内 ...
- Javascript模块化编程(三):require.js的用法
Javascript模块化编程(三):require.js的用法 原文地址:http://www.ruanyifeng.com/blog/2012/11/require_js.html 作者: 阮一峰 ...
- (转)Javascript模块化编程(三):Require.js的用法
转自 ruanyifeng 系列目录: Javascript模块化编程(一):模块的写法 Javascript模块化编程(二):AMD规范 Javascript模块化编程(三):Require.js的 ...
- Javascript模块化编程require.js的用法
JS模块化工具requirejs教程(一):初识requirejs http://www.runoob.com/w3cnote/requirejs-tutorial-1.html JS模块化工具req ...
- javascript模块化编程(三):require.js用法
本文来自阮一峰 这个系列的第一部分和第二部分,介绍了Javascript模块原型和理论概念,今天介绍如何将它们用于实战. 我采用的是一个非常流行的库require.js. 一.为什么要用require ...
- Javascript模块化编程(三):require.js的用法(转)
这个系列的第一部分和第二部分,介绍了Javascript模块原型和理论概念,今天介绍如何将它们用于实战. 我采用的是一个非常流行的库require.js. 一.为什么要用require.js? 最早的 ...
随机推荐
- linux 安装icu库
先下载源码包并解压 然后安装 cd /icu/source ./configure --prefix=/usr/local/icu gmake make install
- Linux安装Tomcat7
linux版本:CentOS 6.2 iso文件下载地址:http://mirrors.163.com/centos/6.2/isos/i386/CentOS-6.2-i386-bin-DVD1.is ...
- oracle case when及decode的用法
case ... when 语句 1) CASE column_name WHEN value1 THEN resutl1,... [ ELSE result ] END select name , ...
- 2. getline()和get()
1.面向行输入:getline() ---其实还可以接受第三个参数. getline()函数读取整行,调用该方法 使用cin.getline().该函数有两个参数, 第一个参数是是用来存储输入行的数组 ...
- Animations and transitions
在交互式可视化中,有一个词叫reactive,指的是以可视化的方式来响应用户的行为,帮助用户进行可视化并理解其结果.这个很有用.那如何来实现这种交互呢?通过动画. 如果处理得当,动画可以展现出不错的可 ...
- Install MongoDB on Linux Systems 速记
下载mongodb最新版本: 下载链接:http://pan.baidu.com/s/1kTDnkyz curl -O http://downloads.mongodb.org/linux/mongo ...
- JDBC学习笔记(三)
获取数据库的元信息metadata,里面有数据库特性的描述信息,如是否支持事务,是否支持批处理等. Connection conn = DriverManager.getConnection(url, ...
- CF518D. Ilya and Escalator [概率DP]
CF518D. Ilya and Escalator 题意:n个人,每秒p的概念队首的人进入电梯,求t秒后期望人数 直接使用期望定义 \(f[i][j]\) i秒后电梯中j个人的概率 注意n个人的时候 ...
- 洛谷 P3672 小清新签到题 [DP 排列]
传送门 题意:给定自然数n.k.x,你要求出第k小的长度为n的逆序对对数为x的1~n的排列 $n \le 300, k \le 10^13$ 一下子想到hzc讲过的DP 从小到大插入,后插入不会对前插 ...
- 夏令营讲课内容整理 Day 5.
DP专场.. 动态规划是运筹学的一个分支, 求解决策过程最优化的数学方法. 我们一般把动态规划简称为DP(Dynamic Programming) 1.动态规划的背包问题 有一个容量为m的背包,有 ...