首页 > 网站 > WEB开发 > 正文

如何改造现有文件为 CMD 模块

2024-04-27 14:11:12
字体:
来源:转载
供稿:网友

如何改造现有文件为 CMD 模块

经过一段考察,我们终于要在项目中引入模块机制和 Sea.js 了,那么如何将现有的文件改造成 CMD 模块就成了重要的问题。下面针对一些典型场景来说明包装的方式。

首先还是请大家详细了解下CMD 模块定义规范,只要洞悉事物的定义和本质,一切问题可迎刃而解。

改造主流模块

这里指的是 jQuery、Moment、Backbone、underscore 等业界主流模块,这些模块一般都有对 AMD 和 CommonJS 的支持代码,例如 jQuery 源文件的最后几行:

if ( typeof module === "object" && module && typeof module.exports === "object" ) {    module.exports = jQuery;} else {    window.jQuery = window.$ = jQuery;    if ( typeof define === "function" && define.amd ) {        define( "jquery", [], function () { return jQuery; } );    }}

还有 Backbone 里:

var Backbone;if (typeof exports !== 'undefined') {  Backbone = exports;} else {  Backbone = root.Backbone = {};}

对于有这些兼容代码的,只需要去掉 define.amd 的支持,或是直接包装上define就可以了。

define(function(require, exports, module) {  // code here ...});

如果没有模块化的兼容代码,有时候需要手动引入依赖,以及暴露对应的接口。

define(function(require, exports, module) {  var $ = require('$');  // code here ...  module.exports = Placeholders;});

可以参考cmdjs/gallery里的Gruntfile对这些主流模块的代码替换方式。

现有的 JS 文件

对于一些现有的普通 JS 文件,相对简单的多,参考 CMD 的书写规范,把那些暴露到全局命名空间的接口用 CMD 的方式进行改造就可以了。

比如现有文件util.js

window.util = window.util || {};util.addClass = function() {  window.CSS();};util.queryString = function() {};

改为:

define(function(require, exports, module) {  // 引入依赖  var css = require('css');  util.addClass = function() {    css();  };  util.queryString = function() {};  // 暴露对应接口  module.exports = util;});

这里不啰嗦,就是基本的 CMD 书写规范。实际的改造过程中,情况可以比上面的例子要复杂一些,具体情况具体解决就行。

改造 jQuery 插件

这也是一个经常遇到的问题,我们推荐以下的包装方式:

// jquery-plugin-abcdefine(function(require, exports, module) {  var $ = require('$');  // 插件的代码  $.fn.abc = function() {};});

这样的改造方式实际上是强化了原有的 $ 对象(而不是重新包装出一个新的 $),在实际调用时,可以用下面的方式:

seajs.use(['$', 'jquery-plugin-abc'], function($) {  // $ 有了 jquery-plugin-abc 所提供的插件功能  $.abc();});

更多 jQuery 插件的包装,可以参考cmdjs/jquery里的做法。

工具

除了手动的方式修改代码外,我们推荐使用Grunt来进行统一的改造,官方也通过 Grunt 改造了很多主流模块和 jQuery 插件,具体的操作手册见引入 CMD 模块指南。你可以在cmdjs/gallery和cmdjs/jquery中找到具体的 Gruntfile ,从而借鉴到您的项目中去。所有打包好的模块可以在spmjs.org中找到。

小结

上面提供的是原有代码包装为CMD 书写规范的方法,在具体上线前,可能还需要打包为具名模块(包含 ID 的模块)。关于构建方面的进一步知识可以参考构建工具。

这里提到的包装方式都比较典型和简单,具体的实践可能千差万别。您在项目中有什么探索、实践和问题,欢迎来这里分享和提问。

内容来源: https://github.com/seajs/seajs/issues/971


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表