工作中使用seajs后的一些总结
工作中用seajs一段时间了,小小地总结一下。
使用seajs五部曲:
1.布置你项目的目录结构
2.设置seajs的config项,我一般是单独一个js文件--> seajs-config.js, 主要是重置一下base路径,一般比较少用paths,而用alias比较多,因为项目上线前直接把alias这些配置给grunt直接构建提取模块id
/**
* 配置项目
*
*/
seajs.config({
"base": "/js",
"paths": {
"seajs": "sea-modules/seajs"
},
"alias": {
"jquery": "sea-modules/library/jquery/1.11.1/jquery.js",
"bindonce": "sea-modules/library/angular/1.2.20/bindonce.js",
"handlebars": "sea-modules/library/handlebars/1.3.0/handlebars.js",
"mustache": "sea-modules/library/mustache/0.8.1/mustache.js",
"angular": "sea-modules/library/angular/1.3.0-beta.15/angular.min.js",
"iscroll5": "sea-modules/library/iscroll/iscroll.js",
"cart": "sea-modules/custom/cart/1.1.0/cart.js",
"favorite": "sea-modules/custom/favorite/0.1.0/favorite.js",
"cookies": "sea-modules/custom/cookies/0.1.0/cookies.js",
"globalloading": "",
"tipslayer": "sea-modules/custom/tipslayer/0.1.0/tipslayer.js",
"verify": "sea-modules/custom/verify/0.1.0/verify.js",
"slider": "sea-modules/custom/slider/0.2.0/slider.js",
"tips": "sea-modules/custom/tips/1.2.0/tips.js",
"share": "sea-modules/custom/share/0.2.0/share.js",
"lazyload": "sea-modules/custom/lazyload/0.1.0/lazyload.js",
"emoji": "sea-modules/custom/emotion/zepto_emoji.js",
"iscroll": "sea-modules/custom/iscroll/4.2.5/iscroll.js",
"dialog": "sea-modules/custom/dialog/1.1.1/dialog.js",
"pageloader": "sea-modules/custom/pageloader/0.1.0/pageloader.js",
"loading": "sea-modules/custom/loading/0.1.0/loading.js",
"report": "sea-modules/custom/report/report.js",
"imgbrowse": "sea-modules/custom/imgbrowse/0.1.0/imgbrowse.js",
},
"map": [
// [".js", ".js?v2"]
],
"debug": 2
});
3.定义模块
define(function(require, exports, module) {
data = 123;
return data; //对外接口
//module.exports = data; //也可这样,对外接口
//exports.data = data; //也可这样,对外接口
});
4.解决依赖 ,在定义模块时,如果依赖其它的文件,直接require一下
define(function(require, exports, module) {
var $ = require('jqeury');
//do something...
data = 123;
return data; //对外接口
//module.exports = data; //也可这样,对外接口
//exports.data = data; //也可这样,对外接口
});
5.调用模块, 在html文件用seajs.use来调一下主文件
<script type="text/javascript">
seajs.use('web/feedback_chat.js');
</script>
实际工作中一般都是在重复这几步,第一个项目的目录的目录结构定下来就不变了, config文件中base一般是不变的了,就是不断的加alias, 然后定义模块, 在模块里require解决依赖, 最后在html文件里 seajs.use调用。
然后再把seajs的路径问题解决基本就OK了--> 这是seajs官网的解释 https://github.com/seajs/seajs/issues/258
之前也小小写了下总结,有点乱没时间整理,也发上来吧--> http://www.cnblogs.com/Ivangel/p/4304811.html
最后就是在项目上线之前用grunt构建一下。这是我写的一个小demo--> https://github.com/ivan403704409/seajs-transport-demo
工作中使用seajs后的一些总结的更多相关文章
- 修复在“Android 在ScrollView中嵌入ViewPage后ViewPage不能很好的工作的问题解决”这篇博客中MyScrollView出现滑动一会就不会上下滑动的问题
在“Android 在ScrollView中嵌入ViewPage后ViewPage不能很好的工作的问题解决”,这篇博客中的大部分问题已经解决了. 唯一遗憾的是,ViewPage随人能够工作了,但是My ...
- 工作中那些提高你效率的神器(第二篇)_Listary
引言 无论是工作还是科研,我们都希望工作既快又好,然而大多数时候却迷失在繁杂的重复劳动中,久久无法摆脱繁杂的事情. 你是不是曾有这样一种想法:如果我有哆啦A梦的口袋,只要拿出神奇道具就可解当下棘手的问 ...
- C# 工作中遇到的几个问题
C# 工作中遇到的几个问题 1.将VS2010中的代码编辑器的默认字体“新宋体”改为“微软雅黑”后,代码的注释,很难对齐,特别是用SandCastle Help File Builder生成帮助文档 ...
- [工作中的设计模式]责任链模式chain
一.模式解析 责任链模式是一种对象的行为模式.在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链.请求在这个链上传递,直到链上的某一个对象决定处理此请求.发出这个请求的客户端并不知 ...
- 总结工作中常见的linux命令
本文是总结下自己在工作中遇到的常见linux 命令,会持续更新! 1.文件路径切换 进入 cd 返回上一级 cd .. 2.复制 cp 源文件名 目标文件夹 cp log.log test5 3.编 ...
- 工作中常用的Linux命令:find命令
本文链接:http://www.cnblogs.com/MartinChentf/p/6056571.html (转载请注明出处) 1.命令格式 find [-H] [-L] [-P] [-D deb ...
- [工作中的设计模式]原型模式prototype
一.模式解析 提起prototype,最近看多了js相关的内容,第一印象首先是js的原型 var Person=function(name){ this.name=name; } Person.pro ...
- [工作中的设计模式]策略模式stategy
一.模式解析 策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.策略模式让算法独立于使用它的客户而独立变化. 策略模式的关键点为: 1.多种算法存在 2.算法继承同样的接口 ...
- 运维工作中sed常规操作命令梳理
sed是一个流编辑器(stream editor),一个非交互式的行编辑器.它一次处理一行内容.处理时,把当前处理的行存储在临时缓冲区中,称为"模式空间",接着用sed命令处理缓冲 ...
随机推荐
- sql 列设置默认值,语法查询知识点积累
一.修改字段默认值 alter table 表名 drop constraint 约束名字 ------说明:删除表的字段的原有约束 alter table 表名 add constraint 约 ...
- ajax 传值 中文乱码问题
使用encodeURI编码内容 var Path = encodeURI("中文.xls"); url: "ashx/Data.ashx?Path =" + P ...
- 移动web前端的一些硬技能(二)动手前必须掌握的基本常识
记得刚开始接触移动端web的时候,书和网上的资料都不多,查起来很费劲,现在比以前要好很多了,可是还是会有一些刚接触移动端的朋友会问我一些我最初会遇到的问题,或许是书本写的并不那么重,也或许是这些知识写 ...
- TeXLive安装过程
Linux系统下TeXLive2016安装教程:http://www.linuxidc.com/Linux/2016-08/133913.htm 安装完成后,在当前用户的 ~/.bashrc 中加入如 ...
- 视听说加速器--AHK辅助工具
大学有视听说这门课,看起来这门课设计得非好,可是对大多数人来讲却不能按时完成.到了最后都要抓紧提速,上网找答案,辛苦的抄,有“聪明者”便找加速器来做. 我也是赶着做的人之一.抄答案太累,加速器太卡,还 ...
- Java程序员需要学习的知识点
Java是全世界最受欢迎的3大编程语言之一,它可以开发出许多实用的WEB应用程序和桌面应用程序,更重要的一点,Java是跨平台的语言——编写一次,可以再任何地方运行.另外,Java也很容易入门,如果你 ...
- USB信号是什么类型的? 为什么在D+,D-处要接上拉下拉电阻呢,具体阻值要如何计算
USB协议要求的,1.5K上拉在D+时表示是全速设备,在D-表示不是全速设备有些方案里面(比如PNX5230)推荐D+/D-接下拉1M的电阻是为了提高数据传输稳定性的 ① usb有主从设备之分,主设 ...
- 有意思的GacUI
所有方法,无论是你写还是工具来codegen还是用宏,最终都指向把这些名字和对应的指针存在一个map里.C++是不提供这个功能的,我也没仔细研究过qt怎么做,不过我在我自己的gacui里面实现了类似的 ...
- cf471A MUH and Sticks
A. MUH and Sticks time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- bzoj1622 [Usaco2008 Open]Word Power 名字的能量
Description 约翰想要计算他那N(1≤N≤1000)只奶牛的名字的能量.每只奶牛的名字由不超过1000个字待构成,没有一个名字是空字体串, 约翰有一张“能量字符串表”,上面有M(1 ...