项目中的前端组件已达到一定规模,平时常常有开发人员来询问我组件的用法,并且已存在很多由于使用不当造成的问题,因此有必要出一份前端组件的使用文档,方便别人,也方便自己。

使用什么样的格式让我费了不少脑筋,使用word不方便别人索取和自己更新;使用wiki,不方便自己编写;使用普通的html,成本很高。觉得如果能做一个类似于Ext Api Doc那样的文档就很不错,使用它很方便,不光能建立起类与类的层级关系,还有很强的搜索功能。隐约感觉Ext Api Doc不是专门用Ext开发出来,而是通过源码里的注释自动生成出来,因为Ext源码里的文档和Doc是一一对应的。所以现在需要做的就是,按照一定的格式完善注释,另外要找到这么一个自动从注释生成Ext类型文档的工具。

通过一番搜索,还真找到这么一个工具,http://www.extjs.com/forum/showthread.php?t=55214,此工具使用起来很方便,但需要注意的是运行它需要jdk1.6,怎么使用看看readme就很清楚了。

接下来,就是要按规定格式完善注释了,重点需要做以下几点:

1)class

需要在每个类前加上注释,标明类的相关信息,例如:

/**
 * @class Ext.plugins.AccountSelector2
 * @extends Ext.plugins.BaseSelector
 * 科目选择控件
 * @alias Ext.plugins.AccountSelector2
 * @author tingjia.chentj@alibaba-inc.com
 */

Ext.plugins.AccountSelector2 = function(config){

......

}

其中@class为类名,@extends为继承的基类,@alias为别名,@autho为作者。

2)cfg

需要在类的每个配置属性前加上注释,大家使用组件最关心这个组件的配置属性,例如:

/**
 * @cfg {Number} width
 * 控件宽度,default:420
 */

其中width为属性名,Number为属性类型

3)@method

需要在类方法前加上注释,例如:

/**
     * 修改某个值引起联动
     * @method updateAmount
     * @param {String} changeField 引发联动的字段(qty、price、disRate、withTax、taxRate、withoutTax)
     * @param {String} newValue 改变后的值
     * @param {record} r record
     * @param {json} defaultValue 默认值
     */
    updateAmount:function(changeField,newValue,r,defaultValue){

    ......

   }

4)@property

需要在类属性前加上注释,例如:

/**
     * combobox控件
     * @type Ext.form.ComboBox
     * @property editor
     */

其中 @property为属性名,@type为属性类型

5)@event

在事件侦听前加上注释,例如

/**
         * @event beforeaction
         * Fires before action event. Return false to cancel the subsequent action event.
         * @param {Ext.grid.GridPanel} grid
         * @param {Ext.data.Record} record Record corresponding to row clicked
         * @param {String} action Identifies the action icon clicked. Equals to icon css class name.
         * @param {Integer} rowIndex Index of clicked grid row
         * @param {Integer} colIndex Index of clicked grid column that contains all action icons
         */
         'beforeaction'

通过对以上五类元素加上注释后,再用工具自动生成,一份很方便和漂亮的文档就出来了,但此文档不能直接打开,得部署到web服务器上,因为此文档的实现用了Ajax,不过这个也很容易,在apache里加上个虚拟目录就搞定了,打开文档,效果如下:

文档效果图

 
posted on 2011-12-14 16:02  一个人的天空@  阅读(662)  评论(1编辑  收藏  举报