一、为什么要用require.js?

最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了。后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载。下面的网页代码,相信很多人都见过。

  <script src="1.js"></script>
  <script src="2.js"></script>
  <script src="3.js"></script>
  <script src="4.js"></script>
  <script src="5.js"></script>
  <script src="6.js"></script>

这段代码依次加载多个js文件。

这样的写法有很大的缺点。首先,加载的时候,浏览器会停止网页渲染,加载文件越多,网页失去响应的时间就会越长;其次,由于js文件之间存在依赖关系,因此必须严格保证加载顺序(比如上例的1.js要在2.js的前面),依赖性最大的模块一定要放到最后加载,当依赖关系很复杂的时候,代码的编写和维护都会变得困难。

require.js的诞生,就是为了解决这两个问题:

  

  (1)实现js文件的异步加载,避免网页失去响应;

  (2)管理模块之间的依赖性,便于代码的编写和维护。

二、require.js的加载(index.html或是product.html中的代码)

使用require.js的第一步,是先去官方网站下载最新版本。

下载后,假定把它放在js子目录下面,就可以加载了。

  <script src="js/require.js"></script>

有人可能会想到,加载这个文件,也可能造成网页失去响应。解决办法有两个,一个是把它放在网页底部加载,另一个是写成下面这样:

  <script src="js/require.js" defer async="true" ></script>

async属性表明这个文件需要异步加载,避免网页失去响应。IE不支持这个属性,只支持defer,所以把defer也写上。

加载require.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。

三、模块的加载(main.js文件中的代码)

一种则是直接配置目录(baseUrl 要求所有的js文件都放在同一个文件夹目录下,如这里都放在js文件下)。

  require.config({

    baseUrl: "js",

<!-- baseUrl,它的作用就是,以它作为基础路径,在这个路径之下,查找文件。我是将所有.js文件都放在js文件夹下的。
                           所以,在require([])或者define([])的依赖数组列表中,写上依赖的文件路径:如require(['jquery','lunbo','car'],function($,l,c){ })

-->

          });

require(['jquery', 'car', 'lunbo',/*依赖的文件路径*/], function ($, car, l,/*依赖模块返回的对象或数组*/){

             // some code here

//调用依赖模块中的属性或方法

   })

二种则是配置路径(paths 路径可以是绝对路径,相对路径,或是远程路径,不要求js文件都放同一个文件夹里面)

  require.config({

   

  paths: {

<!-- paths的作用呢?就是将一些常用的js文件,换成通用的名字。
例如jquery-1.8.2.min.js,我们不可能每次调用它时,都写这一啪啦吧,
所以为了方便,就将jquery替代jquery-1.8.2.min.js咯(给路径起别名),以后我们就可以直接使用jquery(别名)了,快捷方便。 -->

      "jquery": ["jquery","https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min"],

"car":"car",

"lunbo":"lunbo",

"erro":"erro",

"glass":"../放大镜",

"preloading":"../图片预加载"

      

    }

  });

require(['jquery', 'glass', 'lunbo','preloading'/*依赖的文件别名*/], function ($, gla, l,prelo/*依赖模块返回的对象或数组*/){

             // some code here

//调用依赖模块中的属性或方法

   })

三种则是一二两种的结合

require.config({

baseUrl:'js',

paths:{

"glass":"../放大镜",

"preloading":"../图片预加载"

}

})

require(['jquery','car','lunbo','glass','preloading'],function($,car,l,gla,prelo){//回调函数中的参数一 一对应依赖模块返回的对象或函数

l.move();//lunbo.js模块返回的是对象

car();//car.js模块返回的是函数

})

五、标准模块的定义(define())  
1 :模块必须采用特定的define()函数来定义

如:lunbo.js文件中的代码

define(['jquery'],function($){

return{
         "move":function(){
                      $("#a").html("lunbo中执行的代码");
                   

              }

}

})

如:car.js文件中的代码

define(['jquery','lunbo'],function($,l){

return  function  shoping(){

console.log("car中执行的代码")

l.move()//lunbo.js模块返回的是对象

}

})

<!--
define!它的作用是,定义一个js模块,供其他模块或者require使用。
它引用其他js的模块的方法和require差不多,都是将需要的js文件引入,然后参数一一对应。
大家需要要注意的是,define里定义的方法或者变量,其他模块是访问不到的,
所以,你如果想其他模块也能访问,就应该返回(return)对象或者函数都可以。
在这里,我return的是一个对象,提供init供其他模块调用。
-->

六 非标准化的模块(erro.js中的代码)

定义的模块不使用define()函数定义的  都是非标准模块

如:function sucess(){

console.log("非标准模块中执行的代码")

}

//非标准模块中定义的函数 ,由于没有以函数或是对象的形式返回,所以在其他的模块中无法访问

//如果想访问非标准模块中的函数 就必须在require.config()中进行配置

如:   require.config({

baseUrl:'js',

paths:{

'glass':"../放大镜",

"preloading":"../图片与加载"

},

shim{

"erro":{//需要配置的模块名称

exports:'sucess'//非标准模块的函数名

}

}

})

require(['erro'],function(er){

er();//erro.js返回的是当个函数

})

定义的模块不使用define()函数定义的  都是非标准模块

如:function sucess(){

console.log("非标准模块中执行的代码1")

}

function madol(){

console.log("非标准模块中执行的代码2")

}

//非标准模块中定义的函数 ,由于没有以函数或是对象的形式返回,所以在其他的模块中无法访问

//如果想访问非标准模块中的函数 就必须在require.config()中进行配置

如:   require.config({

baseUrl:'js',

paths:{

'glass':"../放大镜",

"preloading":"../图片与加载"

},

shim{

"erro":{//需要配置的模块名称

init:function(){

return {             //配置多个非标准模块的函数名

su:sucess,//注意此时的函数名不用引号

mo:madol

}

}

}

}

})

require(['erro'],function(er){

er.su();//erro.js返回的是对象

er.mo();

})

require.js按需加载使用简介的更多相关文章

  1. webpack require.ensure 按需加载

    使用 vue-cli构建的项目,在 默认情况下 ,会将所有的js代码打包为一个整体比如index.js.当使用存在多个路由代码的时候,index.js可能会超大,影响加载速度. 这个每个路由页面除了i ...

  2. require.js模块化管理和加载js(按需加载)简单实例教学

    一.为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载.下面的网页代 ...

  3. 按需加载.js .css文件

    首先,理解按需加载当你需要用到某个js里面的函数什么鬼,或者某个css里的样式的时候你才开始加载这个文件. 然后是怎样实现的,简单来说就是在js中动态的createElem<script> ...

  4. jQuery中的ready方法及实现按需加载css,js

    模拟jQuery中的ready方法及实现按需加载css,js 一.ready函数的实现 经常用jQuery类库或其他类库中的ready方法,有时候想想它们到底是怎么实现的,但是看了一下jQuery中的 ...

  5. 模拟jQuery中的ready方法及实现按需加载css,js

    一.ready函数的实现 经常用jQuery类库或其他类库中的ready方法,有时候想想它们到底是怎么实现的,但是看了一下jQuery中的源码,涉及到的模块比较多,(水平有限)代码比较难看懂:自己结合 ...

  6. 模拟jQuery中的ready方法及实现按需加载css,js实例代码

    这篇文章介绍了模拟jQuery中的ready方法及实现按需加载css,js实例代码,有需要的朋友可以参考一下     一.ready函数的实现经常用jQuery类库或其他类库中的ready方法,有时候 ...

  7. 深入浅出的webpack4构建工具---webpack+vue+router 按需加载页面(十五)

    1. 为什么需要按需加载? 对于vue单页应用来讲,我们常见的做法把页面上所有的代码都打包到一个bundle.js文件内,但是随着项目越来越大,文件越来越多的情况下,那么bundle.js文件也会越来 ...

  8. Webpack按需加载一切皆模块

    前言 在学习 Webpack 之前,我们需要了解一个概念:模块. 何为模块? 如果你曾学过 Java , C# 之类的语言,一定会知道 Java 中的 import 或 C# 中的 using 吧? ...

  9. webpack中利用require.ensure()实现按需加载

    webpack中的require.ensure()可以实现按需加载资源包括js,css等,它会给里面require的文件单独打包,不和主文件打包在一起,webpack会自动配置名字,如0.js,1.j ...

随机推荐

  1. 笔记:Jersey REST API 设计

    REST 统一接口 REST 使用 HTTP 协议的通用方法作为统一接口的标准词汇,REST 服务所提供的方法信息都在 HTTP 方法里,每一种HTTP请求方法都可以从安全性和幂等性两方面考虑,这对正 ...

  2. poj-3185-开关问题

    描述 牛一行20他们喝的水碗.碗可以那么(面向正确的为清凉水)或颠倒的(一个位置而没有水).他们希望所有20个水碗那么,因此用宽鼻子翻碗. 嘴太宽,他们不仅翻转一碗还碗的碗两侧(总共三个或三个——在两 ...

  3. Spring Boot 1.4测试的改进

    对Pivotal团队来说,工作上的好事情是他们拥有一个被叫做Pivotal Labs的灵活发展部门,拥有Labs团队的Lean 和 XP程序设计方法学的强大支持,例如结对编程和测试驱动开发.他们对于测 ...

  4. php 类接口继承练习

    <?php /** * @hypo 接口的特性:接口中定义的所有方法都必须是public 接口的实现:一个接口可以使用implements操作符,类中必须实现接口中的所有方法,否则会报fatal ...

  5. Python-turtle库知识小结(python绘图工具)

    turtle:海龟(海龟库) Turtle库是Python语言中一个很流行的绘制图像的函数库 使用之前需要导入库:import turtle • turtle.setup(width,height,s ...

  6. Java并发编程实战(chapter_2)(对象发布、不变性、设计线程安全类)

    一.发布与溢出 "发布(Publish)"一个对象的意思是指,使对象能够在当前作用于之外的代码中使用.这个"之外",尤为关键,各种出问题的地方,都是因为这个&q ...

  7. 【Alpha版本】冲刺阶段 - Day7 - 靠泊

    Alpha:指集成了主要功能的第一个试用版本.在这个版本中有些小功能并未实现.事实上很多软件的 Alpha 版本只是在内部使用.给外部用户使用的 Alpha 版本会起一个比较美妙的名字,例如,技术预览 ...

  8. [Redis源码阅读]redis持久化

    作为web开发的一员,相信大家的面试经历里少不了会遇到这个问题:redis是怎么做持久化的? 不急着给出答案,先停下来思考一下,然后再看看下面的介绍.希望看了这边文章后,你能够回答这个问题. 为什么需 ...

  9. jquery 表双击某行时,取出某行中各列的数值.

      <script> $(function () { $("tr").dblclick(function () { var txt = $("table tr ...

  10. EasyUI 修改 Messager 消息框大小

    需求是要修改确认消息窗口的大小. 简单的调用方法是这样的: $.messager.confirm('操作确认', '确定批量编辑文章?', function (r) { ... } 这个时候生成的弹窗 ...