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 相关文章推荐
javascript陷阱 一不小心你就中招了(字符运算)
Nov 10 Javascript
jquery给图片添加鼠标经过时的边框效果
Nov 12 Javascript
jQuery对下拉框,单选框,多选框的操作
Feb 21 Javascript
js生成缩略图后上传并利用canvas重绘
May 15 Javascript
javascript中hasOwnProperty() 方法使用指南
Mar 09 Javascript
jQuery实现的支持IE的html滑动条
Mar 16 Javascript
JS实现列表的响应式排版(推荐)
Sep 01 Javascript
Bootstrap组合上、下拉框简单实现代码
Mar 06 Javascript
微信小程序中使用Promise进行异步流程处理的实例详解
Aug 17 Javascript
详解vue-cli下ESlint 配置说明
Sep 03 Javascript
iview tabs 顶部导航栏和模块切换栏的示例代码
Mar 04 Javascript
vue双向绑定数据限制长度的方法
Nov 04 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
《一拳超人》埼玉一拳下去,他们存在了800年毫无意义!
2020/03/02 日漫
PHP通过串口实现发送短信
2015/07/08 PHP
CI框架AR操作(数组形式)实现插入多条sql数据的方法
2016/05/18 PHP
PHP中session跨子域的三种实现方法
2016/07/25 PHP
PHP面向对象程序设计高级特性详解(接口,继承,抽象类,析构,克隆等)
2016/12/02 PHP
JavaScript库 开发规则
2009/01/31 Javascript
JS去除字符串两端空格的简单实例
2013/12/27 Javascript
js读取配置文件自写
2014/02/11 Javascript
sails框架的学习指南
2014/12/22 Javascript
JavaScript对象创建模式实例汇总
2016/10/03 Javascript
jQuery 插件封装的方法
2016/11/16 Javascript
微信小程序 引入es6 promise
2017/04/12 Javascript
Vue.js基础指令实例讲解(各种数据绑定、表单渲染大总结)
2017/07/03 Javascript
详解.vue文件中style标签的几个标识符
2018/07/17 Javascript
微信小程序:数据存储、传值、取值详解
2019/05/07 Javascript
React优化子组件render的使用
2019/05/12 Javascript
jsonp格式前端发送和后台接受写法的代码详解
2019/11/07 Javascript
[01:05:36]VP vs TNC Supermajor小组赛B组 BO3 第二场 6.2
2018/06/03 DOTA
python利用MethodType绑定方法到类示例代码
2017/08/27 Python
python实现k-means聚类算法
2018/02/23 Python
python中协程实现TCP连接的实例分析
2018/10/14 Python
pyqt5 键盘监听按下enter 就登陆的实例
2019/06/25 Python
pytorch梯度剪裁方式
2020/02/04 Python
python发qq消息轰炸虐狗好友思路详解(完整代码)
2020/02/15 Python
pycharm部署、配置anaconda环境的教程
2020/03/24 Python
PyQt5 文本输入框自动补全QLineEdit的实现示例
2020/05/13 Python
Python判断远程服务器上Excel文件是否被人打开的方法
2020/07/13 Python
python 多线程死锁问题的解决方案
2020/08/25 Python
英国在线女鞋目的地:SIMMI
2018/12/27 全球购物
宝信软件JAVA工程师面试经历
2012/08/19 面试题
统计员岗位职责
2013/11/14 职场文书
银行服务明星推荐材料
2014/05/29 职场文书
2014年学校食堂工作总结
2014/11/25 职场文书
幸福家庭事迹材料
2014/12/20 职场文书
《认识钟表》教学反思
2016/02/16 职场文书
Python爬虫实战之爬取携程评论
2021/06/02 Python