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 相关文章推荐
对联广告js flash激活
Oct 19 Javascript
In Javascript Class, how to call the prototype method.(three method)
Jan 09 Javascript
javascript 三种编解码方式
Feb 01 Javascript
火狐4、谷歌12不支持Jquery Validator的解决方法分享
Jun 20 Javascript
通过JS获取用户本地图片路径并显示的代码
Feb 16 Javascript
JQuery显示隐藏页面元素的方法总结
Apr 16 Javascript
js同源策略详解
May 21 Javascript
javascript 中设置window.location.href跳转无效问题解决办法
Feb 09 Javascript
Ionic + Angular.js实现验证码倒计时功能的方法
Jun 12 Javascript
vue事件修饰符和按键修饰符用法总结
Jul 25 Javascript
微信小程序基于picker实现级联菜单
Feb 15 Javascript
解决vue单页面多个组件嵌套监听浏览器窗口变化问题
Jul 30 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使用CURL实现多线程抓取网页
2015/04/30 PHP
php 调用ffmpeg获取视频信息的简单实现
2017/04/03 PHP
php实现每日签到功能
2018/11/29 PHP
PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
2020/08/03 PHP
Javascript - HTML的request类
2007/01/09 Javascript
DOM和XMLHttpRequest对象的属性和方法整理
2012/01/04 Javascript
JavaScript实现穷举排列(permutation)算法谜题解答
2014/12/29 Javascript
jQuery+ajax实现动态执行脚本的方法
2015/01/27 Javascript
JavaScript获取DOM元素的11种方法总结
2015/04/25 Javascript
setTimeout内不支持jquery的选择器的解决方案
2015/04/28 Javascript
基于JS2Image实现圣诞树代码
2015/12/24 Javascript
javascript实现数组去重的多种方法
2016/03/14 Javascript
基于jquery实现图片放大功能
2016/05/07 Javascript
Vue.js 插件开发详解
2017/03/29 Javascript
vue的常用组件操作方法应用分析
2018/04/13 Javascript
js实现随机div颜色位置 类似满天星效果
2019/10/24 Javascript
vue仿淘宝滑动验证码功能(样式模仿)
2019/12/10 Javascript
基于vue+echarts 数据可视化大屏展示的方法示例
2020/03/09 Javascript
JavaScript多种图形实现代码实例
2020/06/28 Javascript
vue Treeselect 树形下拉框:获取选中节点的ids和lables操作
2020/08/15 Javascript
分析python服务器拒绝服务攻击代码
2014/01/16 Python
Python MySQLdb Linux下安装笔记
2015/05/09 Python
详解python中requirements.txt的一切
2017/03/03 Python
python 与GO中操作slice,list的方式实例代码
2017/03/20 Python
Pycharm学习教程(1) 定制外观
2017/05/02 Python
Python生成密码库功能示例
2017/05/23 Python
PyCharm中代码字体大小调整方法
2019/07/29 Python
python encrypt 实现AES加密的实例详解
2020/02/20 Python
伊莱克斯(Electrolux)俄罗斯网上商店:瑞典家用电器品牌
2021/01/23 全球购物
企业管理培训感言
2014/01/27 职场文书
关于学习的演讲稿
2014/05/10 职场文书
2014年安全员工作总结
2014/11/13 职场文书
详解Nginx启动失败的几种错误处理
2021/04/01 Servers
JS不要再到处使用绝对等于运算符了
2021/04/30 Javascript
浅谈Python协程asyncio
2021/06/20 Python
nginx配置指令之server_name的具体使用
2022/08/14 Servers