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 相关文章推荐
用脚本调用样式的几种方法
Dec 09 Javascript
Javascript remove 自定义数组删除方法
Oct 20 Javascript
基于jquery的获取mouse坐标插件的实现代码
Apr 01 Javascript
javascript题目,重写函数让其无限相加
Feb 15 Javascript
查找Oracle高消耗语句的方法
Mar 22 Javascript
JavaScript验证图片类型(扩展名)的函数分享
May 05 Javascript
基于javascript实现表格的简单操作
May 21 Javascript
Vue.js实现简单动态数据处理
Feb 13 Javascript
JS实现的文件拖拽上传功能示例
May 21 Javascript
vue实现重置表单信息为空的方法
Sep 29 Javascript
JavaScript面试技巧之数组的一些不low操作
Mar 22 Javascript
微信小程序自定义头部导航栏(组件化)
Nov 15 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 _autoload自动加载类与机制分析
2012/02/10 PHP
字符串长度函数strlen和mb_strlen的区别示例介绍
2014/09/09 PHP
php cookie用户登录的详解及实例代码
2017/01/03 PHP
php 类中的常量、静态属性、非静态属性的区别
2017/04/09 PHP
Javascript面向对象编程
2012/03/18 Javascript
改进版通过Json对象实现深复制的方法
2012/10/24 Javascript
javascript和HTML5利用canvas构建猜牌游戏实现算法
2013/07/17 Javascript
浅谈javascript的call()、apply()、bind()的用法
2016/02/21 Javascript
jQuery的ready方法实现原理分析
2016/10/26 Javascript
JavaScript用JSONP跨域请求数据实例详解
2017/01/06 Javascript
微信小程序 开发之滑块视图容器(swiper)详解及实例代码
2017/02/22 Javascript
JavaScript实现替换字符串中最后一个字符的方法
2017/03/07 Javascript
基于JavaScript实现弹幕特效
2020/08/27 Javascript
在vue中读取本地Json文件的方法
2018/09/06 Javascript
[40:05]DOTA2上海特级锦标赛A组小组赛#1 EHOME VS MVP.Phx第一局
2016/02/25 DOTA
python多线程操作实例
2014/11/21 Python
Python内建模块struct实例详解
2018/02/02 Python
Python matplotlib绘图可视化知识点整理(小结)
2018/03/16 Python
Python中数组,列表:冒号的灵活用法介绍(np数组,列表倒序)
2018/04/18 Python
Python中pillow知识点学习
2018/04/30 Python
selenium+python自动化测试之多窗口切换
2019/01/23 Python
Django中的静态文件管理过程解析
2019/08/01 Python
Django实现将一个字典传到前端显示出来
2020/04/03 Python
Python selenium爬取微博数据代码实例
2020/05/22 Python
利用纯CSS3实现文字向右循环闪过效果实例(可用于移动端)
2017/06/15 HTML / CSS
CSS3 mask 遮罩的具体使用方法
2017/11/03 HTML / CSS
新英格兰最大的特色礼品连锁店:The Paper Store
2018/07/23 全球购物
《夸父追日》教学反思
2014/02/26 职场文书
yy婚礼司仪主持词
2014/03/14 职场文书
教学质量评估实施方案
2014/03/17 职场文书
《生命的药方》教学反思
2014/04/08 职场文书
学校党委副书记个人对照检查材料思想汇报
2014/09/28 职场文书
2014年最新离婚协议书范本
2014/10/11 职场文书
2015教师个人工作总结范文
2015/03/31 职场文书
如何利用 CSS Overview 面板重构优化你的网站
2021/10/24 HTML / CSS
Python开发五子棋小游戏
2022/04/28 Python