“仅做一件事,做好一件事。”

这个应该就是seaJs的精髓了。

我在自己的一些项目中使用过seaJs。对其算是了解一二。如今就班门弄斧。轻轻地谈一下。

首先上一段度娘的话:

seaJs是一个遵循CommonJs规范的JavaScript模块载入框架,能够实现JavaScript的模块化开发及载入机制。与jQuery等JavaScript框架不同。SeaJS不会扩展封装语言特性,而仅仅是实现JavaScript的模块化及按模块载入。SeaJS的主要目的是令JavaScript开发模块化并能够轻松愉悦进行载入,将前端project师从繁重的JavaScript文件及对象依赖处理中解放出来。能够专注于代码本身的逻辑。SeaJS能够与jQuery这类框架完美集成。使用SeaJS能够提高JavaScript代码的可读性和清晰度。解决眼下JavaScript编程中普遍存在的依赖关系混乱和代码纠缠等问题,方便代码的编写和维护。”

1.下载seaJs

下载url:https://github.com/seajs/seajs

我们能清楚地看到,docs是文档。dist是压缩好的、用于浏览器端的SeaJS代码;src则是源码。

package.json + Gruntfile.js就是Grunt构建工具所须要的文件。用来合并压缩等等。

看完代码结构,如今就開始说一下里面的基本使用方法。

2.seaJs的基本使用方法

2.1 用seajs.config来进行路径和文件依赖的配置。

譬如:

seajs.config({

  // 别名配置
alias: {
'es5-safe': 'gallery/es5-safe/0.9.3/es5-safe',
'json': 'gallery/json/1.0.2/json',
'jquery': 'jquery/jquery/1.10.1/jquery'
}, // 路径配置
paths: {
'gallery': 'https://a.alipayobjects.com/gallery'
}, // 变量配置
vars: {
'locale': 'zh-cn'
}, // 映射配置
map: [
['http://example.com/js/app/', 'http://localhost/js/app/']
], // 预载入项
preload: [
Function.prototype.bind ? '' : 'es5-safe',
this.JSON ? '' : 'json'
], // 调试模式
debug: true, // Sea.js 的基础路径
base: 'http://example.com/path/to/base/', // 文件编码
charset: 'utf-8'
});

更加具体的配置 ,能够參考:https://github.com/seajs/seajs/issues/262

2.2 用seajs.use在页面中载入一个或多个模块,callback 參数可选。省略时,表示无需回调。

继续看代码:

// 载入模块 common,并在载入完毕时,运行指定回调
seajs.use('./common', function(main) {
common.init();
});
// // 并发载入模块 x 和模块 y。并在都载入完毕时,运行指定回调
seajs.use(['./x', './y'], function(x, y) {
x.init();
y.init();
});

2.3 用define定义模块和获取模块。

详细调用例如以下:

define(function(require, exports, module) {

  // 你要写的模块代码

});

2.4用require 获取指定模块的接口。

define(function(require) {

  // 获取模块 x 的接口
var x = require('./x'); // 调用模块 x 的方法
x.doSomething();
});

2.5 用require.async在模块内部异步载入一个或多个模块。

define(function(require) {

  // 异步载入一个模块,在载入完毕时。运行回调
require.async('./b', function(b) {
b.doSomething();
}); // 异步载入多个模块,在载入完毕时。运行回调
require.async(['./c', './d'], function(c, d) {
c.doSomething();
d.doSomething();
}); });

ps:此段代码copy自官网參考文档。

2.6用exports在模块内部对外提供接口。

define(function(require, exports) {

  //这一句对外提供了一个属性todo
exports.todo = 'wt'; });

3.注意和规范

肤浅地过了一遍主要的使用方法之后,接下来就说一下要注意的东西了。

3.1模块工厂构造方法的第一个參数 必须 命名为 require 。

// 错误!
define(function(req) {
// ...
});
// 错误!
define(function(r) {
// ...
}); // 正确!
define(function(require) {
// ...
});

3.2不要给 require 又一次赋值或者不能把这个函数重命名。

// 错误
var yilai = require, a= yilai ("./mod"); // 错误
require = function() {}; // 错误
function todo(require) {} // 错误
function todo() {
var require = function() {};
}

3.3require 的參数值不能是字符串直接量之外的其它变量。

// 错误!
require(todo); // 错误!
require("to-" + "do"); // 错误!
require("todo".toLowerCase());

总结:使用 Sea.js。提高代码的可维护性。高效性。灵活性。粒子性和可移植性。总结得有点虚,可是seaJs确实给项目的开发带来了非常多的便利。

还不用seaJs。你就凹凸慢了。

注:此 文章參考了官网的非常多文章,编写而来。想知道得很多其它的童鞋。请点击这里:http://seajs.org/docs/#docs

Author: Alone

Antroduction: 高级前端开发project师

Sign: 人生没有失败。仅仅有没到的成功。

博主相关文章推荐:

有趣的前端题目。看了不懊悔

移动端前端开发概述

浅谈
标签的语义化

浅谈鼠标滚轮事件

不积跬步无以至千里----高度自适应的textarea

sass和less,优秀的前端样式预处理器

视差滚动的那些事儿


轻轻谈一下seaJs——模块化开发的利器的更多相关文章

  1. 初学seaJs模块化开发,利用grunt打包,减少http请求

    原文地址:初学seaJs模块化开发,利用grunt打包,减少http请求 未压缩合并的演示地址:demo2 学习seaJs的模块化开发,适合对seajs基础有所了解的同学看,目录结构 js — —di ...

  2. seaJs模块化开发简单入门

    随着前端技术的日益成熟,功能越来越丰富强大,规范也越来越健全,在这样的背景环境下很快便有了CommonJs.AMD.CMD等一系列规范,使前端发开趋向模块化.规范化.CMD模块化的代表之一就是国内开发 ...

  3. seajs模块化开发

    seajs是一个起辅助作用的库,所以它可以更方便开发,而它可以解决以下问题: 1.命名问题,就是冲突 2.性能问题,就是只要一个功能,但却使用一个大插件中的一个小功能,所以要手动拆分出这个功能 3.j ...

  4. 2.精通前端系列技术之JavaScript模块化开发 seajs(一)

    在使用seajs模块化开发之前,直接在页面引用js会容易出现冲突及依赖相关的问题,具体问题如下 问题1:多人开发脚本的时候容易产生冲突(比如全局参数冲突,方法名冲突),可以使用命名空间降低冲突,不能完 ...

  5. JS模块化开发(一)——seaJs

    模块化开发要解决的问题: 1.冲突 比如:多人协作开发时,不同js库中的函数重名问题 可以用命名空间解决: var module={} module.a=1; module.b=function(){ ...

  6. JS模块化开发:使用SeaJs高效构建页面

    一.扯淡部分 很久很久以前,也就是刚开始接触前端的那会儿,脑袋里压根没有什么架构.重构.性能这些概念,天真地以为前端===好看的页面,甚至把js都划分到除了用来写一些美美的特效别无它用的阴暗角落里,就 ...

  7. JavaScript模块化开发库之SeaJS

    SeaJS是一个很好的前端模块化开发库,源码不到1500行,压缩后才4k,质量极高.

  8. seajs进行模块化开发

    seajs进行模块化开发 模块化前端开发入门指南(二) 2015-08-26 15:23 by paseo, 370 阅读, 0 评论, 收藏, 编辑 概览 使用seajs模块化加载器进行模块化开发, ...

  9. seajs的模块化开发--实践笔记

    2017-04-02 SeaJS是一个遵循CMD规范的JavaScript模块加载框架,可以实现JavaScript的模块化开发及加载机制.有效的解决复杂项目中命名冲突.依赖.性能等问题. SeaJS ...

随机推荐

  1. jQuery粘性跟随滚动条滚动的导航栏源代码下载

    jQuery粘性跟随滚动条滚动的导航栏源代码下载 作者:网页模板 大小:0.005MB 点击次数:3494 发布时间:2014-03-07 12:55 分享到:0 特效介绍 jQuery粘性跟随滚动条 ...

  2. [置顶] 通过实例学习Struts2 (1)

    前言 一直用Struts1 , 现在新的项目要转向Struts2了, 先研究学习一下,做点技术储备. 我一直认为计算机软件行业是一个实践性非常强的行业,书读了多少都不管用, 一定要卷起袖子,亲自动手, ...

  3. JQuery(上)

    1.流行的JavaScript类库   --  框架.插件 )为了简化 JavaScript 的开发, 一些 JavsScript 库诞生了. JavaScript 库封装了很多预定义的对象和实用函数 ...

  4. SQLServer,仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表xx中的标识列指定显式值

    情景: 如果此表的主键或者其中有一个列使用了  IDENTITY(1,1) 自增长时,但又想手动为此列指定值时,当用如下解决方案: set identity_insert 表名 ON 使用此命令把表的 ...

  5. VS2015 开发人员命令提示,如何实现记事本编程

    开始,选择VS2015 开发人员命令提示,打开 找到.c文件的位置,复制位置 在VS2015 开发人员命令提示, 输入cd 位置 回车 然后输入cl 文件名 回车 这样进行编译

  6. JavaScript中的计时器原理

    理解John Resig 在 How JavaScript Timers Work. 原理分析 timer(setInterval,setTimeout)有一个很重要的概念,时间延迟的长短是不稳定的. ...

  7. vue+webpack一些知识

    使用mac的用户需要获取权限才可以使用npm install指令 设置node目录的权限指令 sudo chmod -R 777 /usr/local/lib/node_modules/ 大家都知道国 ...

  8. bootstrap-js(5)工具提示tooltip

    实例 当您想要描述一个链接的时候,工具提示(Tooltip)就显得非常有用.工具提示(Tooltip)插件是受 Jason Frame 写的 jQuery.tipsy 的启发.工具提示(Tooltip ...

  9. 在node.js中使用ejs的demo 第五篇

    先说明一下我的项目的目录解构: 本项目中渲染的时候都是通过在index.js页面里面,来使用index.ejs的,首先引用必须的模块: var express = require('express') ...

  10. poj2459 Treasure Exploration (闭包+二分)

    这道题是让求派出机器人的最少数量,乍一看以为是简单的求最小路径覆盖,后来发现错了,因为有的点可以走多次,而二分中每个点只能走一次,所以要先用floyd进行传递闭包,然后用二分 #include< ...