前言

前端模块化能解决什么问题?

  1. 模块的版本管理
  2. 提高可维护性 -- 通过模块化,可以让每个文件职责单一,非常有利于代码的维护
  3. 按需加载 -- 提高显示效率
  4. 更好的依赖处理 -- 传统的开发模式,如果B依赖A,那么必须在B文件前面先加载好A。如果使用了模块化,只需要在模块内部申明依赖即可。

AMD规范 & CMD规范

说到前端模块化,就不得不提AMD规范中文版英文版)和CMD规范英文版

它们的区别:

http://www.zhihu.com/question/20351507

http://www.cnblogs.com/tugenhua0707/p/3507957.html

AMD规范是 RequireJS 在推广过程中对模块定义的规范化产出,所以我在这里重点介绍下 AMD规范。

AMD规范全名异步模块定义(Asynchronous Module Definition)规范,让模块和依赖可以异步加载。

主要API:

define(id?, dependencies?, factory);

id,字符串,定义中模块的名字,可选参数(没有提供,则默认为模块加载器请求的指定脚本的名字),如果提供,那么模块名必须是顶级和绝对的(不允许相对名字)

dependencies,数组,模块的依赖,可选参数

factory,函数或对象,必选参数。

RequireJS

RequireJS是一个JS的文件和模块加载器。专门为浏览器优化,同时也支持其他JS环境。

使用RequireJS

要想使用requireJS,首先需要在页面引入脚本:

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

接下来,书写脚本:

<script>
requirejs(['js/a'], function(a){
alert(a.test);
});
</script>

  

再来看看a.js:

define({
test: 'aa'
});

  

html代码如下:

<!DOCTYPE html>
<html>
<head>
<title>RequireJS Demo</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta http-equiv="X-UA-Compatible" content="chrome=1">
<script src="assets/vendor/require/require.js"></script>
</head>
<body>
<script>
requirejs(['assets/js/a'], function(a){
alert(a.test);
});
</script>
</body>
</html>

  

在浏览器中打开后,弹出aa。

在实践这个简单示例的时候,需要注意requireJS的baseUrl 设置:

细节之处

1、RequireJS 加载文件/模块都是相对于baseUrl的

2、baseUrl默认使用data-main属性指定的脚本目录

//baseUrl="assets/"
<script data-main="assets/main" src="assets/vendor/require/require.js"></script> //baseUrl="assets/js/"
<script data-main="assets/js/main" src="assets/vendor/require/require.js"></script>

  

3、如果没有data-main属性,那么baseUrl等于该html所在的目录

4、baseUrl可以通过RequireJS config进行设置

5、优先级:config > data-main属性 -> html目录

6、RequireJS加载JS时,可以不写js后缀

7、加载文件/模块时,会自动包含前缀http或者https

8、可以在config中使用paths配置,指定相对目录

//这是我的项目目录结构
www/
index.html
assets/
js/
a.js
vendor/
require/
require.js
main.js //配置文件
requirejs.config({
baseUrl: 'assets',
paths: {
js: 'js'
}
}); //可以直接使用js来映射目录,进行文件引用
requirejs(['js/a'], function(a){
alert(a.test);
});

  

注意:一定要保证使用paths的时候,一定要放在config之后。通过在配置paths时,如果是直接子目录,不需要斜杠。

9、data-main指定的文件,是requirejs的入口点

定义模块

在requirejs中,我们可以采用多种方式定义模块,如下:

1、简单的键值对:

define({
color: 'black',
size: '18px'
});

  

2、定义函数:

define(function(){
return {
color: 'black',
size: '18px'
};
});

  

3、定义函数并使用依赖:

define(['a', 'b'], function(a, b){
return {
color: 'black',
size: '18px',
alert: function(){
return a.num + b.num;
}
};
});

  

4、将函数定义为模块:

define(['a', 'b'], function(a, b){
return function(title){
return title ? title : a.title + b.title;
};
});

  

5、通过简单的CommonJs包装器定义模块:

define(function(require, exports, module){
var a = require('a'),
b = require('b');
return function(){};
});

  

6、定义包含名字的模块:

define('moduleA', ['a', 'b'], function(a, b){
//do something...
});

  

配置项

requirejs.config({
baseUrl: '', //基地址
paths: { //路径映射
'js': '../js'
},
bundles: { //
primary: ['main', 'util'],
secondary: ['text!secondary.html']
},
shim: { //从非模块的js中,导出模块
jquery: {
deps: [],
exports: 'jQuery'
}
},
map: { //方便版本控制
'some/newmodule': {
'foo': 'foo1.2'
},
'some/oldmodule': {
'foo': 'foo1.0'
}
},
config: { //配置module
bar: {
size: 'large'
}
},
packages: [], //需要从CommonJS packages中加载的模块
nodeIdCompat: true,
waitSeconds: 15, // 加载脚本超时时间(秒)
context: '', //设置上下文名称
deps:[], //需要加载的依赖
callback: function(){}, //当deps加载完时执行
enforceDefine: false, // 是否当脚本没有define时抛出错误
xhtml: false, //是否使用xhtml创建脚本元素
urlArgs: 'test=' + (new Date()).getTime(), //配置url参数
scriptType: 'text/javascript', //设置加载脚本的脚本类型
skipDataMain: false //是否使用data-main属性
});

原博主:幻天芒

原文地址:http://www.cnblogs.com/humin/p/4435070.html

前端模块化:RequireJS(转)的更多相关文章

  1. 前端模块化:RequireJS

    前言 前端模块化能解决什么问题? 模块的版本管理 提高可维护性 -- 通过模块化,可以让每个文件职责单一,非常有利于代码的维护 按需加载 -- 提高显示效率 更好的依赖处理 -- 传统的开发模式,如果 ...

  2. 前端模块化开发之seaJs

    了解后端语言的童鞋一定听过模块化开发的概念,比如java.python等后端语言都有自己的模块化特性,然而和后端语言相比,javascript还尚未实现模块化的功能,虽然之后的更高版本可能引入模块化开 ...

  3. 前端angularjs+requirejs+dhtmlx 后端asp.net webapi

    享一个前后端分离方案源码-前端angularjs+requirejs+dhtmlx 后端asp.net webapi   一.前言 半年前左右折腾了一个前后端分离的架子,这几天才想起来翻出来分享给大家 ...

  4. JAVAScript:前端模块化开发

    目录 一:前端模块化概要 1.1.模块化概要 1.2.函数封装 1.3.对象封装 1.4.立即执行函数表达式(IIFE) 1.5.模块化规范 1.5.1.CommonJS 1.5.2.AMD((Asy ...

  5. 回顾:前端模块化和AMD、CMD规范(全)

    先列举下一些著名言论: "我想定义一个 each 方法遍历对象,但页头的 util.js 里已经定义了一个,我的只能叫 eachObject 了,好无奈." "Requi ...

  6. JavaScript学习总结(六)——前端模块化开发

    早期的javascript版本没有块级作用域.没有类.没有包.也没有模块,这样会带来一些问题,如复用.依赖.冲突.代码组织混乱等,随着前端的膨胀,模块化显得非常迫切. 前端模块化规范如下: 一.前端模 ...

  7. 前端模块化 、包管理器、AMD、 CMD、 require.js 、sea.js

    问题由来,为什么要前端模块化管理: 假设我们有个组件名为Acomponent.js, 是架构封装的,里面依赖另一个公司公用库common.js: 那我们引入Acomponent.js的时候,怎么知道要 ...

  8. WEB 前端模块化,读文笔记

    文章链接 WEB 前端模块化都有什么? 知识点 根据平台划分 浏览器 AMD.CMD 存在网络瓶颈,使用异步加载 非浏览器 CommonJS 直接操作 IO,同步加载 浏览器 AMD 依赖前置 req ...

  9. js前端模块化之加载器原理解析(一)

    先来说一下前端模块化的价值:引用模块此处有详细的介绍,可以自行前往观看. 一.总结如下优点: (1)解决命名冲突(2)烦琐的文件依赖(3)模块的版本管理(4)提高可维护性(5)前端性能优化(6)跨环境 ...

随机推荐

  1. JavaScript数据可视化编程学习(二)Flotr2,雷达图

    一.雷达图 使用雷达图显示多维数据. 如果你有多维的数据要展示,那么雷达图就是一种非常有效的可视化方法. 由于雷达图不常用,比较陌生,所以向用户解释的时候有一些难度.注意使用雷达图会增加用户认知负担. ...

  2. CentOS下安装Tomcat 8

    CentOS下安装Tomcat 8 安装Tomcat8 去http://tomcat.apache.org/download-80.cgi下载Tomcat8的安装文件apache-tomcat-8.0 ...

  3. flex布局元素操作详情

    之前布局一直用的是 position,float之类的,趁着国庆学习一下 flex 布局 父元素: flex-direction: row row-reverse column column-reve ...

  4. 去除url后缀(.html,.jsp等)的有效方法

    有时候,我们想要隐藏真正的路径,或者觉着很酷,举一个知乎网的例子,如https://www.zhihu.com/question/39547745 那么?如何做到呢,其实,可以有一个非常简单而有效的解 ...

  5. web-iPhone X

    题目: 解题思路: 第一次看到html里只有字其他啥也没有的题,一脸懵逼,学长提示抓包改包,于是开始我的苦逼解题. 0x01 抓包 0x02 改包 由于题目说只有iphoneX才能接受这个websit ...

  6. 一个Win32API Trace Tool的设计与实现

    用VC编程也有不短的时间了,对kernel32.advapi32.user32.gdi32等动态库里的API多数都已经很熟悉了.API是操作系统提供给应用程序的一组服务,很久以前就想要做个小工具,用来 ...

  7. ccf 火车购票

    import java.util.ArrayList; import java.util.List; import java.util.Scanner; public class Main2 { pu ...

  8. Python函数篇

    1.函数名的命名规则: 函数名必须以下划线或字母开头,可以包含任意字母.数字或下划线的组合.不能使用任何的标点符号: 函数名是区分大小写的. 函数名不能是保留字. 2. 形参和实参 形参:形式参数,不 ...

  9. markdown 字体颜色

     Markdown是一种可以使用普通文本编辑器编写的标记语言,通过类似HTML的标记语法,它可以使普通文本内容具有一定的格式.但是它本身是不支持修改字体.字号与颜色等功能的!   CSDN-markd ...

  10. 基于 HTML5 Canvas 的 3D 模型列表贴图

    少量图片对于我们赋值是没有什么难度,但是如果图片的量大的话,我们肯定希望能很直接地显示在界面上供我们使用,再就是排放的位置等等,这些都需要比较直观的操作,在实际应用中会让我们省很多力以及时间.下面这个 ...