LABjs、RequireJS、SeaJS的区别


Posted in Javascript onMarch 04, 2014

一、LABjs 的核心是 LAB(Loading and Blocking):Loading 指异步并行加载,Blocking 是指同步等待执行。LABjs 通过优雅的语法(script 和 wait)实现了这两大特性,核心价值是性能优化。LABjs 是一个文件加载器。

二、RequireJS 和 SeaJS 则是模块加载器,倡导的是一种模块化开发理念,核心价值是让 JavaScript 的模块化开发变得更简单自然。模块加载器也可降级为文件加载器用,因此使用 RequireJS 和 SeaJS,也可以达成 LABjs 的性能优化目的。

三、RequireJS 和 SeaJS 都是很不错的模块加载器,两者区别如下:

1. 两者定位有差异。RequireJS 想成为浏览器端的模块加载器,同时也想成为 Rhino / Node 等环境的模块加载器。SeaJS 则专注于 Web 浏览器端,同时通过 Node 扩展的方式可以很方便跑在 Node 服务器端
2. 两者遵循的标准有差异。RequireJS 遵循的是 AMD(异步模块定义)规范,SeaJS 遵循的是 CMD (通用模块定义)规范。规范的不同,导致了两者 API 的不同。SeaJS 更简洁优雅,更贴近 CommonJS Modules/1.1 和 Node Modules 规范。
3. 两者社区理念有差异。RequireJS 在尝试让第三方类库修改自身来支持 RequireJS,目前只有少数社区采纳。SeaJS 不强推,而采用自主封装的方式来“海纳百川”,目前已有较成熟的封装策略。
4. 两者代码质量有差异。RequireJS 是没有明显的 bug,SeaJS 是明显没有 bug。
5. 两者对调试等的支持有差异。SeaJS 通过插件,可以实现 Fiddler 中自动映射的功能,还可以实现自动 combo 等功能,非常方便便捷。RequireJS 无这方面的支持。
6. 两者的插件机制有差异。RequireJS 采取的是在源码中预留接口的形式,源码中留有为插件而写的代码。SeaJS 采取的插件机制则与 Node 的方式一致:开放自身,让插件开发者可直接访问或修改,从而非常灵活,可以实现各种类型的插件。

还有不少细节差异就不多说了。

总之,SeaJS 从 API 到实现,都比 RequireJS 更简洁优雅。如果说 RequireJS 是 Prototype 类库的话,则 SeaJS 是 jQuery 类库。
最后,向 RequireJS 致敬!RequireJS 和 SeaJS 是好兄弟,一起努力推广模块化开发思想,这才是最重要的。

Javascript 相关文章推荐
使用GruntJS链接与压缩多个JavaScript文件过程详解
Aug 02 Javascript
jQuery实现用户注册的表单验证示例
Aug 28 Javascript
jquery 漂亮的删除确认和提交无刷新删除示例
Nov 13 Javascript
使用coffeescript编写node.js项目的方法汇总
Aug 05 Javascript
如何利用JS通过身份证号获取当事人的生日、年龄、性别
Jan 22 Javascript
js仿3366小游戏选字游戏
Apr 14 Javascript
bootstrap table 多选框分页保留示例代码
Mar 08 Javascript
jQuery用noConflict代替$的实现方法
Apr 12 jQuery
微信小程序 聊天室简单实现
Apr 19 Javascript
3分钟掌握常用的JS操作JSON方法总结
Apr 25 Javascript
每个 JavaScript 工程师都应懂的33个概念
Oct 22 Javascript
深入理解 TypeScript Reflect Metadata
Dec 12 Javascript
js的Boolean对象初始值示例
Mar 04 #Javascript
js动态拼接正则表达式的两种方法
Mar 04 #Javascript
8个实用的jQuery技巧
Mar 04 #Javascript
js中top的作用深入剖析
Mar 04 #Javascript
父页面显示遮罩层弹出半透明状态的dialog
Mar 04 #Javascript
深入理解JS中的变量及作用域、undefined与null
Mar 04 #Javascript
css+js实现部分区域高亮可编辑遮罩层
Mar 04 #Javascript
You might like
PHP实现把数字ID转字母ID
2013/08/12 PHP
2个Codeigniter文件批量上传控制器写法例子
2014/07/25 PHP
php、java、android、ios通用的3des方法(推荐)
2016/09/09 PHP
JavaScript面向对象之体会[总结]
2008/11/13 Javascript
Js日期选择器并自动加入到输入框中示例代码
2013/08/02 Javascript
js实现动态添加、删除行、onkeyup表格求和示例
2013/08/18 Javascript
node-webkit打包成exe文件被360误报木马的解决方法
2015/03/11 Javascript
JS解析XML文件和XML字符串详解
2015/04/17 Javascript
JavaScript实现可拖拽的拖动层Div实例
2015/08/05 Javascript
js与jQuery实现checkbox复选框全选/全不选的方法
2016/01/05 Javascript
javascript 将共享属性迁移到原型中去的实现方法
2016/08/31 Javascript
jQuery事件绑定用法详解
2016/09/08 Javascript
jQuery  ready方法实现原理详解
2016/10/19 Javascript
微信小程序 vidao实现视频播放和弹幕的功能
2016/11/02 Javascript
详解vue-cli开发环境跨域问题解决方案
2017/06/06 Javascript
解决bootstrap下拉菜单点击立即隐藏bug的方法
2017/06/13 Javascript
微信小程序实现自上而下字幕滚动
2018/07/14 Javascript
微信小程序3种位置API的使用方法详解
2019/08/05 Javascript
Vue向后台传数组数据,springboot接收vue传的数组数据实例
2020/11/12 Javascript
python调用java模块SmartXLS和jpype修改excel文件的方法
2015/04/28 Python
Django框架中方法的访问和查找
2015/07/15 Python
Python Scapy随心所欲研究TCP协议栈
2018/11/20 Python
Python实现一个简单的毕业生信息管理系统的示例代码
2020/06/08 Python
在 Windows 下搭建高效的 django 开发环境的详细教程
2020/07/27 Python
一款恶搞头像特效的制作过程 利用css3和jquery
2014/11/21 HTML / CSS
关于canvas绘制模糊问题的解决方法
2019/09/24 HTML / CSS
西班牙英格列斯百货法国官网:El Corte Inglés法国
2017/07/09 全球购物
办公文员的工作岗位职责
2013/11/12 职场文书
竞选大队委员演讲稿
2014/04/28 职场文书
媒矿安全生产承诺书
2014/05/23 职场文书
2014年最新离婚协议书范本
2014/10/11 职场文书
2014年领导班子工作总结
2014/12/11 职场文书
公司更名通知函
2015/04/24 职场文书
法人代表证明书范本
2015/06/18 职场文书
MySQL中存储时间的最佳实践指南
2021/07/01 MySQL
Nginx流量拷贝ngx_http_mirror_module模块使用方法详解
2022/04/07 Servers