sea.js模块化工具
sea.js
一、
sea.js向全局中引入了两个变量seajs、define;
1、seajs用加载文件
seajs.use(deps,callback)异步引入入口模块
路径要以sea.js文件所在的目录为准
参数:
deps:可以是一个字符串,也可以是一个数组;如果是一个字符串表示要引入的文件地址;如果是一个数组,表示加载多个模块文件。
callback:回调函数,模块文件加载进来之后执行的事情
回调函数的参数是对应的模块向外暴露的内容
eg:
seajs.use(["js/A.js", "js/B.js"])
注意:seajs.use不能引入具备id的模块,因为第一个参数既是文件的路径又是文件的id
2、define定义模块
只有当参数是函数的时候才有意义
(1)一个参数定义模块
define(content)当content为非函数时,定义即暴露;当content是函数时,暴露如下:
define(function(require, exports, module) {
这种定义方式默认暴露一个对象出去
})
(2)两个参数定义模块
第一种方式:define(id,handler)
参数:id:当前模块的id;handler:当前模块的函数体
第二种方式:define(deps,handler)
参数:deps:当前模块所依赖的其他模块,数组类型;handler:当前模块的函数体
(3)三个参数定义模块
define(id,deps,handler)
参数:id:当前模块id;deps:当前模块所依赖的其他模块,数组类型;handler:当前模块的函数体
二、模块暴露
(1)定义即暴露
define(非函数)
(2)使用exports向外暴露
打点或方括号添加属性
define(function(require,exports,module){
exports.a = 10;
})
(3)使用module.exports向外暴露
打点或方括号添加属性
module.exports.a = 10;
(4)使用this向外暴露,只可以打点向外暴露内容
(5)使用return向外暴露
三、加载具备id的模块
seajs.use无法引入 具备id的模块
原因:seajs.use方法的参数接收的既是文件的路径有事模块的id,所以能加载默认模块,因为默认模块的路径和id一致;
当模块具备id时,seajs.use只可以完成第一步:加载文件;但是第二步:加载模块完成不了。
//把A文件作为入口文件,然后把BB(带id的模块)模块暴露,在A文件里面通过require引入BB模块文件;在index.html文件中引入A模块文件
//想要引入BB.js模块文件中的a模块,无法使用seajs.use;
//所以使用A.js引入BB.js文件中的a模块
index.html:
seajs.use("A.js",function(b) {
// console.log(b)
})
A.js:
define(["js/BB.js"],function(require, exports, module) {
var b = require("a")
console.log(b)
})
BB.js:
define("a",function(require,exports,module) {
module.exports.a = 12;
})
四、require.async()用法同seajs.use
五、模块配置
配置需要使用seajs.config方法
1、paths:值是一个对象,用来配置路径,方便跨目录调用
用法:
seajs.config({
psth:{
key: value;//用所有的key代替value
}
});
案例:
index.html:
seajs.config({
//paths值是一个对象,用来配置路径,所有的key代替value
paths: {
"j":"js"//AA.js文件在js文件夹下,用j来代替js路径
}
})
//此处在引用模块文件时就可以用j
seajs.use("j/AA",function(a) {
console.log(a) //输出111
})
AA.js:
define(function(require,exports,module) {
module.exports.aa = 111;
})
2、alias:值是一个对象,用来给文件起别名
用法:
seajs.config({
alias:{
key: value;//用所有的key代替value
}
});
案例:
index.html:
seajs.config({
//alias给一个文件起别名
alias: {
"b": "js/AA" //把AA模块文件起别名为b
}
})
//此处引入AA.js文件时就可以用b代替
seajs.use("b",function(a) {
console.log(a) //输出111
})
AA.js:
define(function(require,exports,module) {
module.exports.aa = 111;
})
3、map:映射,可用于路径转换;例如,将数组中的第一个全部按照规则映射成第二个
案例:
seajs.config({
// 映射
map: [
// 将数组中的第一个 全部按照规则映射成第二个
['http://example.com/js/app/', 'http://localhost/js/app/']
]
});
4、vars:变量配置
案例:
index.html:
seajs.config({
vars: {
a: "BB"
}
})
seajs.use("js/AA",function(a) { })
AA.js:
define(["js/BB"],function(require,exports,module) {
var lang = require("js/{a}")//加载的是js/BB.js
console.log(lang) //输出12
})
BB.js:
define(function(require,exports,module) {
module.exports.dd = 12;
})
5、base:配置根目录
六、require.async:模块内部异步加载一个或多个模块;用法跟seajs.use一样。
案例:
define(function(require){
require.async(['aModule','bModule'],function(a,b){ // 异步加载多个模块,在加载完成时,执行回调
a.func();
b.func();
})
});
sea.js模块化工具的更多相关文章
- JS模块化工具require.js教程(二):基本知识
前一篇:JS模块化工具我们以非常简单的方式引入了requirejs,这一篇将讲述一下requirejs中的一些基本知识,包括API使用方式等 基本API require会定义三个变量:define,r ...
- 【转】JS模块化工具requirejs教程(二):基本知识
前一篇:JS模块化工具requirejs教程(一):初识requirejs 我们以非常简单的方式引入了requirejs,这一篇将讲述一下requirejs中的一些基本知识,包括API使用方式等. 基 ...
- 【转】JS模块化工具requirejs教程(一):初识requirejs
随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签来导入一个个的js文件这种方式已经不能满足现在互联网开发模式,我们需要团队协作.模块复用.单元测试等等一系列复杂的需求 ...
- sea.js模块化编程
* 为什么要模块化? 解决文件依赖 解决命名冲突 ; var var2 = 2; function fn1(){ } function fn2(){ } return { fn1: fn1, fn2: ...
- JS模块化工具requirejs教程(一):初识requirejs
随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签来导入一个个的js文件这种方式已经不能满足现在互联网开发模式,我们需要团队协作.模块复用.单元测试等等一系列复杂的需求 ...
- JS模块化工具require.js教程(一):初识require.js
随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签来导入一个个的js文件这种方式已经不能满足现在互联网开发模式,我们需要团队协作.模块复用.单元测试等等一系列复杂的需求 ...
- 【requirejs】JS模块化工具requirejs教程
初识requirejs 随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签来导入一个个的js文件这种方式已经不能满足现在互联网开发模式,我们需要团队协作.模块复用.单元 ...
- JS模块化工具requirejs教程01
转自:http://www.runoob.com/w3cnote/requirejs-tutorial-1.html 随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签 ...
- JS模块化工具requirejs教程(二):基本知识
基本API require会定义三个变量:define,require,requirejs,其中require === requirejs,一般使用require更简短 define 从名字就可以看出 ...
随机推荐
- js 显示 base64编码 的二进制流 图片
Data URI scheme.Data URI scheme是在RFC2397中定义的,目的是将一些小的数据,直接嵌入到网页中,从而不用再从外部文件载入.比如上面那串字符,其实是一张小图片,将这些字 ...
- js函数 标签: javascript 2016-08-12 16:48 56人阅读 评论(0) 收藏
函数实际上是对象,函数名实际上也是一个指向函数对象的指针. 使用不带圆括号的函数名是访问函数指针,而非调用函数. 函数声明和函数表达式: alert(test(2,3)); function test ...
- IIS7.5使用web.config设置伪静态的方法
IIS 7和IIS 7.5及以后的版本估计都会使用web.config来实现伪静态规则,于是我们以前的伪静态文件必须更改.网上找了一圈,还没有发现比较全面的web.config伪静态规则,于是我们这里 ...
- python 类属性及限制
Student类本身需要绑定一个属性直接在class中定义属性,这种属性是类属性,归Student类所有:class Student(object): name = 'Student'类的所有实例都可 ...
- 合并两个数组 以KEY 作为键
<?php $a= array( array( 'ID'=> 2 ) ); $b= array( arr ...
- lnmp环境下nginx配置‘负载均衡’
NGINX负载均衡分发请求的几种方式: 1.轮询(默认)每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除.2.weight 指定轮询几率,weight和访问比率成正比 ...
- npm创建react项目
1:win+R 输入cmd ,打开cmd面板 2:安装cnpm npm install -g cnpm --registry=https://registry.npm.taobao.org 3:安装r ...
- awrsqrpt.sql简介
ORACLE_HOME/RDBMS/admin/awrsqrpt.sql 这个脚本可以很方便地取出某个sql在某两个快照间隔内,消耗cpu时间,执行次数,逻辑读,物理读,sql的执行计划以及sql的 ...
- 使用with子句优化代码中重复查询
/*好处: 1. 性能更好,一份复制(类似SYS_TMP...),多份使用. 2. 结构清晰,预先定义. 3. 代码修改不必修改多处. 请注意观察语句1和语句2执行 ...
- Linux 命令行 发送邮件
1.mail -s hi xx@yy.com 给xx@yy.com发一封主题为hi的信(没有正文) 编辑完内容后Ctrl-D结束. 2.echo "This is a test mail!& ...