本文不谈如下概念:1. AMD/CMD;2. F2E模块化开发。是的,本文就是要指向内心,为需要使用requirejs构建中小型web应用的亲们提供参考。
我们在创建项目时,一般都需要先考虑以下几个问题,那我们就从问题入手,来陈述。
项目成员一块为项目模块,功能添砖加瓦,那么最直接的手段就是分功能模块来并行开发,公共模块还能提升开发效率。这里的动作就好比是张开手臂,是开放的动作,后面的构建上线
就是一个合的动作,这样一个完美的拥抱才算是完成了。那么这里的模块,具体来说就是JS组件,我们全部采用requirejs的风格来定义,来看代码
// 1.标准的原生JS类定义 (function() { function Validation(args) { this.init(args); } Validation.prototype = { constructor: Validation, init: function(args) { } } Validation.defaults = { }; if (typeof define === "function" && define.amd) { define(["bin/parsley"], function() { return Validation; }); } else { window.Validation = Validation; } })(window); // 2.利用模拟OOP的类库来定义 (function(window, document) { var Dropdown = Class.extend({ className: 'dropdown' /** * 构造函数 * @param {Object} args 单一配置对象 */ init: function(args) { } }); if (typeof define === 'function' && define.amd) { define(function() { return Dropdown; }); } else { window.Dropdown = Dropdown; } })(window, document);
你写一个Validation,我写一个Dropdown,你又写一个Slider,我再写一个Autocomplete,从此我们大手拉小手,再也不乱了...
做到只需要改资源引用目录就实现切换开发与调试(未打包压缩)版本,以下是目录结构
jssrc
bin
lib
widget
effect
js
与jssrc一致
其中js中的目录与jssrc一致并且是由grunt中requirejs任务生成的。做好这些,只需要在程序的layout文件引用资源时,通过改变脚本资源的目录即可实现开发与调试的切换。
使用grunt.js,在package.json中加入 "grunt-contrib-requirejs" 依赖,然后在Gruntfile.js中加入name为"requirejs"的task,代码如下
requirejs: { compile: { options: { appDir: 'jssrc/', dir: 'js/', baseUrl: '.', optimize: 'uglify2', // optimize: 'none', // for development mainConfigFile: 'jssrc/main.js', modules: [ { name: 'common' }, { name: 'index' }, { name: 'house-base' }, { name: 'effect/house-detail' }, { name: 'collection' }, { name: 'effect/house-photo-play' }, { name: 'activity-base' }, { name: 'esf-base' }, { name: 'mfb-base' } ], // generateSourceMaps: true, // preserveLicenseComments: false, logLevel: 0, findNestedDependencies: true, fileExclusionRegExp: /^\./, inlineText: true } } }
关键在"modules"的节点的配置,例"common"这个,在jssrc中存在common.js这个文件,是一个模块,看定义代码
define([ 'ga', 'widget/tooltip', 'widget/autocomplete', 'widget/slider', 'effect/global', 'bin/jquery.placeholder' ], function( GA, Tooltip, Autocomplete, Slider, EffectGlobal ) {}
那么我们通过grunt之后,即会在js目录中生成同名的common.js文件,此文件是将所有依赖的模块合并且压缩的结果。那么我们这里再回头看调试的实现,生产页面中引用的是js/common.js,爽死全部依赖都已正确合并到一个文件里并且压缩了。要切换成调试通过统一修改脚本目录为jssrc,则引用jssrc/common.js,如此这样,commons.js中会去拉同在jssrc中的所有依赖的模块,且都是未压缩的独立文件,哪里出个错,直接定位过去,再也不用担心找不到错误啊!~~