由来:
在软件开发过程中,模块化编程思想已经习以为常了,模块化编程不仅仅给开发团队带来效率方面上的好处,还能够让开发的项目或者产品维护成本大大降低。
那么,在WEB开发过程中JS脚本语言已经不可或缺了,通过JS脚本语言能够带来更加舒适的人机交互和用户体验。但是,JS脚本的使用过程中也会有出现引用依赖的混乱,那么JS脚本语言的模块化思想势必会得到大家广泛的认可,在这样的一个背景下,淘宝前端工程师玉伯带来了SeaJS脚本语言,让模块化编程思想进入到JS脚本的世界里。
特点:
SeaJS是一个遵循CommonJS规范的JavaScript模块加载框架,可以实现JavaScript的模块化开发及加载机制。与jQuery等JavaScript框架不同,SeaJS不会扩展封装语言特性,而只是实现JavaScript的模块化及按模块加载。SeaJS的主要目的是令JavaScript开发模块化并可以轻松愉悦进行加载,将前端工程师从繁重的JavaScript文件及对象依赖处理中解放出来,可以专注于代码本身的逻辑。SeaJS可以与jQuery这类框架完美集成。使用SeaJS可以提高JavaScript代码的可读性和清晰度,解决目前JavaScript编程中普遍存在的依赖关系混乱和代码纠缠等问题,方便代码的编写和维护。
SeaJS本身遵循KISS(Keep It Simple, Stupid)理念进行开发,其本身仅有个位数的API,因此学习起来毫无压力。在学习SeaJS的过程中,处处能感受到KISS原则的精髓——仅做一件事,做好一件事。
优势:从一个例子中来看SeaJS优势,
传统模式:
var M1={
run:function(){
alert('M1');
M2.run();
}
}
var M2={
run:function(){
alert('M2');
}
}
<script src="./M2.js"></script>
<script src="./M1.js"></script>
使用SeaJS之后:
//init.js
define(function(require, exports, module) = {
var m1=require('M1');
exports.init=function(){
m1.run();
}
});
//M1.js
define(function(require,exports,module)={
var m2=require('M2');
exports.run=function(){
alert('M1');
m2.run();
}
});
define(function(require,exports,module)={
exports.run=function(){
alert('M2');
}
});
<script src="./sea.js"></script>
<script>
seajs.use('./init', function(init) {
init.init();
});
</script>
通过两个简单的实例能够看出使用SeaJS之后代码的模块化非常清晰,并且在HTML页面中仅仅引用一个./sea.js文件并且仅仅调用init即可,具体init后面实现的逻辑对用户是透明的。
通过这篇博客能够对SeaJS脚本语言有所了解,后面文章介绍利用SeaJS编写模块。