* 为什么要模块化?

  • 解决文件依赖
  • 解决命名冲突

* JS中模块的定义

通常,我们可以这样定义一个模块。
利用闭包特性定义一个模块,对全局暴露一个变量,外部不能访问模块内部定义的变量和方法。
  1. 立即执行函数,闭包
  2. var myModule = (function(){
  3. var var1 = 1;
  4. var var2 = 2;
  5. function fn1(){
  6. }
  7. function fn2(){
  8. }
  9. return {
  10. fn1: fn1,
  11. fn2: fn2
  12. };
  13. })();

node.js中的模块化

node中模块的引入是同步的,遵循CommonJS规范。

sea.js

       遵循CMD (通用模块定义) ,对于依赖的模块,就近依赖,延迟执行。

sea.js写法

  1. define(function(require,exports,module){
  2. var a = require('./a')
  3. a.todo()
  4. //***省略100行
  5. var b = require('./b') //依赖就近书写
  6. b.todo()
  7. //.....
  8. })

define定义模块

    define函数用来定义模块
        define(factory)  factory为模块的构造方法
  1. define(function(require,exports,module){
  2. // 模块代码
  3. });

        define(id?,deps?,factiory)
            id表示模块标识,数组deps是模块依赖,两个参数都可以省略,可以通过构建工具自动生成。

修改jquery为CMD模块

define.cmd Object  一个空对象,可用来判定当前页面是否有 CMD 模块加载器:

对于非seajs模块化的类库,我们可以手动定义它,通过define的cmd规范定义就可以正常使用了
  1. if (typeof define === 'function' && define.cmd) {
  2. define(function (require, exports, module) {
  3. module.exports = jQuery;
  4. })

 暴露接口

exports
module.exports
return

一定不能为exports赋值对象,因为exports仅仅是module.exports的一个引用

  1. define(function(require,exports){
  2.  // 第一种
  3. exports.foo = 'bar';
  4. exports.do = function(){}
  5. //第二种
  6. return {
  7. foo : 'bar',
  8. do : function(){}
  9. };
  10. //第三种
  11.    module.exports = {
  12.        foo : 'bar',
  13.        do : function(){};
  14. }
  15. });

启动

  1. <script type="text/javascript" src="sea.js"></script>
  2. <script>
  3. seajs.use('main/main') //这个文件会第一个被sea.js加载
  4. </script>

sea.js模块化编程的更多相关文章

  1. 从273二手车的M站点初探js模块化编程

    前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...

  2. require.js实现js模块化编程(一)

    1.认识require.js: 官方文档:http://requirejs.org/RequireJS是一个非常小巧的JavaScript模块载入框架,是AMD规范最好的实现者之一.最新版本的Requ ...

  3. require.js实现js模块化编程(二):RequireJS Optimizer

    require.js实现js模块化编程(二):RequireJS Optimizer 这一节,我们主要学习一下require.js所提供的一个优化工具r.js的用法. 1.认识RequireJS Op ...

  4. 初步理解require.js模块化编程

    初步理解require.js模块化编程 一.Javascript模块化编程 目前,通行的Javascript模块规范共有两种:CommonJS和AMD. 1.commonjs 2009年,美国程序员R ...

  5. [转]js模块化编程之彻底弄懂CommonJS和AMD/CMD!

    原文: https://www.cnblogs.com/chenguangliang/p/5856701.html ------------------------------------------ ...

  6. JS模块化编程之加载器原理

    世面上有好多JavaScript的加载器,比如 sea.js, require.js, yui loader, labJs...., 加载器的使用范围是一些比较大的项目, 个人感觉如果是小项目的话可以 ...

  7. js模块化编程总结

    大家都知道,js中的变量(variable)有其作用范围,比如:函数里用var定义的变量在函数外是看不到的,而定义在函数外面的变量(不能有没有var修饰)均是全局变量,在js程序的任何位置都可以访问. ...

  8. js模块化编程之彻底弄懂CommonJS和AMD/CMD!

    先回答我:为什么模块很重要? 答:因为有了模块,我们就可以更方便地使用别人的代码,想要什么功能,就加载什么模块.但是,这样做有一个前提,那就是大家必须以同样的方式编写模块,否则你有你的写法,我有我的写 ...

  9. 好文推荐系列-------(5)js模块化编程

    本文主要来源于阮一峰的<Javascript模块化编程>系列文章整合,原文地址:http://www.ruanyifeng.com/blog/2012/10/javascript_modu ...

随机推荐

  1. nuget常用命令

    nuget命令的用法: 一.安装 1.安装指定版本类库install-package <程序包名> -version <版本号> 2.安装到指定的项目install-packa ...

  2. Mono 3.8发布:性能进一步改进,可伸缩性提升

    9月4日,Mono 3.8.0发布了.该版本的运行时带来了一些性能和可伸缩性方面的改进,同时完成了向Windows平台的移植. Mono遵循Gnome和Linux内核的版本编号策略,这意味着3.8是3 ...

  3. ABP源码分析三十:ABP.RedisCache

    ABP 通过StackExchange.Redis类库来操作Redis数据库. AbpRedisCacheModule:完成ABP.RedisCache模块的初始化(完成常规的依赖注入) AbpRed ...

  4. ABP框架 - 验证数据传输对象

    文档目录 本节内容: 简介 使用数据注解 自定义验证 禁用验证 正常化 简介 一个应用的输入应当先要验证,这个输入可能来自用户或另一个应用,在一个web应用里,验证通常实现两次:在客户端和在服务端,客 ...

  5. 学习python

    最近感觉Python 很不错的样子,乘着这次寒假,不如就先学一下吧. 翻看了一些教程,发现<python 简明教程>质量上乘. 我目前学习python就是打算做一些上位机之类的,好像有点杀 ...

  6. MySQL中You can't specify target table for update in FROM clause一场

    mysql中You can't specify target table <tbl> for update in FROM clause错误的意思是说,不能先select出同一表中的某些值 ...

  7. 异步与并行~List<T>是线程安全的吗?

    返回目录 题目有点意思,大家都知道Dictionary<K,V>不是线程安全的类型,而List<T>是线程安全的吗?在今天之前大叔没有去测试过,而就在今天也是一个VIP问我,说 ...

  8. iOS 多个播放器同时播放,双击全屏,单击退出全屏

    前言:公司需求如下:点击一个按钮播放一个视频,最多同时播放4个:双击某视频让其全屏,单击再恢复原来的样子.IOS的播放器有两种,MPMoviePlayerController,AVAudioPlaye ...

  9. C#定时任务组件之FluentScheduler

    FluentScheduler是.NET开源处理定时任务组件 1.任务的创建注册 public static void TaskActionByMinutes(Action action, int c ...

  10. Bootstrap3系列:导航

    1. 标签页 .nav添加.nav-tabs设计标签页,.nav-tabs 依赖 .nav 基类. 1.1 示例代码 <ul class="nav nav-tabs"> ...