首页 > 编程语言 > 详细

JavaScript Patterns 2.12 Writing API Docs

时间:2014-05-27 17:53:05      阅读:481      评论:0      收藏:0      [点我收藏+]

Free and open source tools for doc generation:

the JSDoc Toolkit (http://code.google.com/p/jsdoc-toolkit/)

and YUIDoc (http://yuilibrary.com/projects/yuidoc).

 

Process of generating API documentation

? Writing specially formatted code blocks

? Running a tool to parse the code and the comments

? Publishing the results of the tool, which are most often HTML pages 

bubuko.com,布布扣
/**

* Reverse a string

*

* @param {String} input String to reverse

* @return {String} The reversed string

*/

var reverse = function (input) {
     // ...
     return output;
}; 
bubuko.com,布布扣

 The contents of app.js starts like this:

bubuko.com,布布扣
/**

* My JavaScript application

*

* @module myapp

*/
bubuko.com,布布扣

Then you define a blank object to use as a namespace:

var MYAPP = {};

And then you define an object math_stuff that has two methods: sum() and multi(): 

bubuko.com,布布扣
/**

* A math utility

* @namespace MYAPP

* @class math_stuff

*/

MYAPP.math_stuff = {

    /**

    * Sums two numbers

    *

    * @method sum

    * @param {Number} a First number

    * @param {Number} b The second number

    * @return {Number} The sum of the two inputs

    */

    sum: function (a, b) {
        return a + b;
    },

/**

* Multiplies two numbers

*

* @method multi

* @param {Number} a First number

* @param {Number} b The second number

* @return {Number} The two inputs multiplied

*/
    multi: function (a, b) {
        return a * b;
    }
}; 
bubuko.com,布布扣

@namespace

The global reference that contains your object.

@class

A misnomer (no classes in JavaScript) that is used to mean either an object or a constructor function.

@method

Defines a method in an object and specifies the method name.

@param

Lists the arguments that a function takes. The types of the parameters are in curly braces, followed by the parameter name and its description.

@return

Like @param, only it describes the value returned by the method and has no name. 

? @constructor hints that this “class” is actually a constructor function

? @property and @type describe properties of an object

bubuko.com,布布扣
/**

* Constructs Person objects

* @class Person

* @constructor

* @namespace MYAPP

* @param {String} first First name

* @param {String} last Last name

*/

MYAPP.Person = function (first, last) {

    /**

    * Name of the person

    * @property first_name

    * @type String

    */
    this.first_name = first;

    /**

    * Last (family) name of the person

    * @property last_name

    * @type String

    */
    this.last_name = last;
};

 

/**

* Returns the name of the person object

*

* @method getName

* @return {String} The name of the person

*/

MYAPP.Person.prototype.getName = function () {
    return this.first_name + ‘ ‘ + this.last_name;
};
bubuko.com,布布扣

YUIDoc Example

bubuko.com,布布扣

JavaScript Patterns 2.12 Writing API Docs,布布扣,bubuko.com

JavaScript Patterns 2.12 Writing API Docs

原文:http://www.cnblogs.com/haokaibo/p/Writing-API-Docs.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!