模块化前端开发入门指南(二)

概览

使用seajs模块化加载器进行模块化开发,以及它的一些弊端。javascript

使用seajs进行模块化开发

项目目录

  1. 新建新项目
  2. 引入sea.js,文件路径modules/sea.js
  3. 引入公共库jquery。
  4. 新建index.html,index.js

项目目录以下:
Alt texthtml

关于sea.js的公共模块路径
sea.js加载时,会自动获取sea.js所在的路径,将sea.js文件存放的路径作为公共模块的根目录。
以modules/sea.js为例,require('a')加载的是modules/a.js模块,require('a/b')加载的是modules/a/b.js模块。java

index.html内容以下:jquery

<!--index.html-->


<!doctype html>
<html>
    <head>
        <title>使用seajs进行模块化开发</title>
        <!--引入公共库-->
        <script src="libs/jquery.js"></script>
    </head>
    <body>
        <div id="container"></div>
        
        <!--引入seajs-->
        <script src="modules/sea.js"></script>      

        <!--引入index.html业务脚本-->
        <script>
            seajs.use('./scripts/index')
        </script>   
    </body>
</html>

建立模块

建立文件modules/moduleA.js。接上篇三种封装形式,使用CMD规范后,分别是这样:git

// 建立jquery插件形式,不须要返回值
// 使用方法require('moduleA'),返回为null
define(function(require, exports, module) {
    
    //$为公共模块
    $.fn.moduleA = function(options) {

    };
});


//Object字面量方式
define(function(require, exports, module) {

    module.exports = {
        fn1: function() {},
        fun2: functdion() {}
    };
});


//prototype继承,new Function方式
define(function(require, exports, module) {
    function moduleA() {
        //constructor
    }

    moduleA.prototype.fn1 = function() {};
    moduleA.prototype.fn2 = function() {};

    module.exports = moduleA;
});

模块的使用

/*
    jquery插件形式的模块加载方式
    */
define(function(require, exports, module) {

    //加载模块
    require('moduleA'); 

    //使用
    $('body').moduleA();
});


/*
Object形式
*/
define(function(require, exports, module) {

    //加载模块
    var moduleA = require('moduleA');

    //使用
    moduleA.fn1();
    moduleA.fn2();

});


/*
原型链继承, new Function形式
*/
define(function(require, exports, module) {

    //加载模块
    var ModuleA = require('moduleA');

    //使用
    var moduleA = new ModuleA();
    moduleA.fn1();
    moduleA.fn2();

});

总结

seajs做为一款国人创造的一个工具库,一直是被放在与requirejs齐平的地位上探讨,我的以为很是不易。使用方式也简单易懂。并且有配套的打包和构建工具,作工程化也不是问题。不足之处是文档不足,提供的工程化产品在国外的grunt、gulp、bower、browserify、components等工程化产品的生态和完整使用文档冲击下,受众很少。github

延伸阅读

如何改造现有文件为CMD模块
玉伯回答seajs和其余模块加载器的异同
玉伯近期说要给seajs立碑悼念,知乎人的见解gulp

相关文章
相关标签/搜索