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


    概览

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

    使用seajs进行模块化开发

    项目目录

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

    项目目录如下:
    Alt text

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

    index.html内容如下:

    <!--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规范后,分别是这样:

    
    // 创建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等工程化产品的生态和完整使用文档冲击下,受众不多。

    延伸阅读

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

  • 相关阅读:
    BZOJ 1202 狡猾的商人 差分约束or带权并查集
    BZOJ 1270 雷涛的小猫 dp
    Spring Cloud探路(三)REST 客户端Feign
    AWS Credentials 使用
    Spring Cloud探路(二) Erueka客户端的建立
    Spring Cloud探路(一) Erueka服务器的建立
    Spring-Mybatis 异常记录(1)
    Amazon Kinesis Producer Library 使用记录
    MQTT开发小记(一)
    利用VSCode进行.Net Core初尝试
  • 原文地址:https://www.cnblogs.com/paseo/p/4760527.html
Copyright © 2020-2023  润新知