YUIDoc を使用した JavaScript ドキュメントの文書化
コードの文書化はテストに似ています。そうすべきであることは誰もが知っていますが、その方法はよくわかりません。正直に言うと、ほとんどの人はまったく実行しませんが、実行する人はそうします。それを行うのは彼らです 大きなサポーターです。このチュートリアルは、この問題を解決する最良の方法の 1 つである YUIDoc をすぐに理解するのに役立ちます。
YUIDocとは何ですか?
YUIDoc は、作成したコメントに基づいて API ドキュメントを生成します。
YUIDoc は、JavaScript ソース コードに記述したコメントに基づいて API ドキュメント (HTML 形式) を生成する NodeJS アプリケーションです。実際、JavaScript だけで動作するわけではありません。/* */
で区切られたブロック コメントをサポートするプログラミング言語であれば、YUIDoc で動作します。ご想像のとおり、YUIDoc は Yahoo! のツールの 1 つです。 YUI ライブラリとともにリリースされました。
YUIDoc をインストールするには、まず NodeJS と Node Package Manager (npm) をインストールする必要があります。その後、npm -g install yuidocjs
を使用して YUIDoc をインストールできます。これを使用するには、yuidoc <js></js>
; を実行します。詳細については後ほど説明します。
重要なのはタグです
つまり、YUIDoc はソース ファイル内の複数行のコメントからドキュメントを取得することがわかりました。もちろん、文書に含まれないコメントがある場合もあります。 YUIDoc がコメントを重要なものとして認識するには、コメントが /**
という二重文字で始まる必要があります。それで:###
リーリー
主なタグ
メイン タグを入力する前に、コメント ブロックごとにメイン タグは 1 つだけ使用できることに注意してください。これらは、コードの特定のブロックが何であるかを説明します。
@モジュール
@module タグは、関連するクラスのグループを記述します。 (はい、はい、JavaScript にはクラスがありません。YUIDoc はコンストラクターを指します。) YUIDoc を使用して BackboneJS を文書化する場合、
Backbone オブジェクトには
Model## が含まれるため、モジュールになります。 、コレクション
、ビュー
およびその他のカテゴリ。ラベルの後にモジュールの名前を配置します。
リーリー
######@クラス######
#@class
@class でタグ付けされた各コメントには、
@static
または @constructor タグも必要です (補助タグについては後ほど説明します)。
リーリー
クラスがモジュールの一部である場合、
@class コメントで指定するために何もする必要はありません。
@module コメントがあることを確認してください。ファイルの先頭にあるブロック、つまり Can.
######@方法######
@method タグを使用します。メソッド名はラベルの後にあり、補助ラベル
@return および
@params
リーリー
######@財産######
@property
タグは、クラスのプロパティをマークするために使用されます。もちろん、@type および
@default 補助タグを使用する必要があります。
リーリー
######@イベント######
クラスでトリガーできる特別なカスタム イベントがある場合は、
@event
ブロックは @method
ブロックに似ていますが、@return
は無関係であり、@param
はコールバックがリッスンするイベント オブジェクトで受信した Hang プロパティを記述するために使用されます。
補助タグ
コメント ブロックには複数のセカンダリ タグを含めることができます。通常、同じタイプのタグがいくつか、場合によっては複数含まれます。よく使うものをいくつか見てみましょう。
@extends
モジュールをサブモジュールに分割する場合 (ファイルごとに 1 つのサブモジュール、またはそうでない場合もあります)、
@submoduleタグが役に立ちます。
リーリー@延長
タグは、スーパークラス/サブクラスの関係がある場合に便利です。どのクラスが現在記録されているクラスの親クラスであるかを宣言できます:
リーリー ######@コンストラクタ######
クラスをインスタンス化できる場合は、コンストラクターが必要であることを意味します。 JavaScript で標準のプロトタイプ パターンを使用する場合、クラス宣言もコンストラクターになります。つまり、次のようなものが頻繁に表示されます:
/** @class Recipe @constructor */ function Recipe () {}
事实上,您可能还记得我说过每个 @class
标记都应该有 @constructor
或 @static
辅助标记。
@static
说到@static
,就在这里。当您无法创建类的实例时,该类被视为静态。一个很好的例子是内置的 Math
对象:您永远不会创建它的实例 (new Math()
),您从类本身调用它的方法。
/** @class MathHelpers @static */ var MathHelpers = {};
方法也可以是静态的:如果一个类可以实例化,但也有一些类级方法,则这些方法被认为是静态的(它们在类上调用,而不是在实例上调用)。
/** @class Person @constructor */ function Person () {} /** @method all @static */ Person.all = function () {};
在此示例中,您可以创建一个 Person
实例,但 all
方法是静态的。
@final
此标签用于属性或特性,并将所述属性标记为常量:不应更改。虽然 JavaScript 在当前状态下没有真正的常量,但原则上您的编码模式或样式指南可能会使用它们,因此这对此很有用。
/** @property DATE_FORMAT @final */ var DATE_FORMAT = "%B %d, %Y";
@param
这里有一个重要的:@param
标签用于定义@method
(包括@constructor
)或@event
的参数。 @param
标记后面有三部分信息:参数名称、类型(可选)和描述。这些可以按顺序 名称类型描述
或 类型名称描述
;但无论哪种情况,类型都必须用花括号括起来。
/** @method greet @param person {string} The name of the person to greet */ function greet (person) {}
还有几种方法可以自定义 name
部分。将其放在方括号中将其标记为可选,而将 =someVal
放在它后面显示默认值是什么(显然,只有可选参数才有默认值)。然后,如果它是多个参数的占位符,请附加 *
来显示这一点。 (显然,name*
是 1 个或多个参数的占位符,而 [name]*
是 0 个或多个参数的占位符)。
/** @class Template @constructor @param template {String} The template string @param [data={}] {Object} The object whose properties will be rendered in the template */ function Template (template, data) {}
@return
大多数方法都希望返回一个值,因此这是描述该值的标签。不要忘记告诉它该值是什么类型,并给出描述。
/** @method toHTML @param [template=Recipe.defaultTemplate] {Template} A template object @return {String} The recipe contents formatted in HTML with the default or passed-in template. */ Recipe.prototype.toHTML = function (template) { return "whatever"; };
@type
还记得 @property
主标记吗?您需要定义这些属性的类型,对吧?好吧, @type
标签正是您所需要的。标记后指定类型;您还可以通过用竖线分隔来提供多种类型:
/** @property URL @type String */ URL: "https://code.tutsplus.com", /** @property person @type String|Person|Object */ this.person = new Person();
@private
/ @protected
传统编程语言提供私有属性或方法:无法从实例外部访问这些属性或方法。就像常量一样,JavaScript 仅在实践中拥有它们,但如果您使用它们,则可以使用 @private
来标记它们。请注意,YUIDoc 不会在它生成的文档中显示私有属性(这是有道理的),因此这允许您为了自己的利益而记录功能,而不是让它显示在文档中。
/** @method _toString @private */ var _toString = Object.prototype.toString.call;
受保护的属性和方法介于公共和私有之间:它们只能从实例和子类的实例中访问。如果您在 JavaScript 中执行此操作,请使用以下标签:@protected
。
@requires
如果某个模块依赖于一个或多个其他模块,可以使用 @requires
来标记:
/** @module MyFramework.localstorage @requires MyFramework */
请注意,@requires
还可以获取依赖项列表,以逗号分隔。
@default
声明 @property
时,您可能会发现给它一个 @default
值很有用。 @default
应始终与 @type
一起使用。
/** @property element @type String @default "div" */ element: "div",
@uses
就像我们所说的,JavaScript 并没有真正的类,但它足够灵活,可以创建类甚至子类的假象。更酷的是,它足够灵活,可以拥有 mixins 或模块:这是一个类从另一个类“借用”属性或方法的地方。而且它也不是继承,因为您可以混合多个类的各个部分(当然,YUI 有能力做到这一点,但 Dojo 和其他库也能做到这一点)。如果您这样做,您会发现 @uses
非常有用:它可以让您声明给定类混合了哪些类。
/** @class ModalWindow @uses Window @uses DragDroppable */ var ModalWindow = new Class({ mixes: [Window, DragDroppable], ... });
注意:我刚刚编写了 mixin 语法,但我很确定我在某处看到过类似的东西。
@example
想要包含如何使用特定代码段的示例吗?使用 @example
标签,然后编写下面的示例,并将其缩进一级。您可以添加任意数量的示例。
/** @method greet @example person.greet("Jane"); */ Person.prototype.greet = function (name) {};
@chainable
您可能熟悉 jQuery 中的可链接方法。您知道,您可以在哪里从方法调用中调用方法,因为方法返回对象?使用 @chainable
标记您的方法。
/** @method addClass @chainable */ jQuery.prototype.addClass = function (class) { // stuff; return this; }
@已弃用的
/ @since
/ @beta
这三个标签都是关于对代码的支持(可以是任何代码:模块、类、方法或其他代码)。使用 @deprecated
将某些功能标记为不再是最佳方法(已弃用的功能可能会在未来版本的代码中删除)。或者,您可以添加一条消息来解释当前的执行方式。
/** @method toJSON @deprecated Pass the object to `JSON.parse` instead */ Something.toJSON = function () {};
@since
标签只是告诉读者给定代码添加了什么版本。 @beta
标记 beta 代码:YUI 建议 @beta
代码可能“在不久的将来经历向后不兼容的更改。 ”
/** @class Tooltip @since 1.2.3 @constructor */ function Tooltip () {}
@extension
/ @extensionfor
/ extension_for
@extension
标签(及其别名)与 @uses
几乎相反。用它来标记扩展类可以混合到哪些类中。当然,要意识到这并不意味着它总是混合在一起,只是它可以混合在一起。
/** @class Draggable @extensionfor ModalWindow */
评论和 Markdown
在我们查看实际示例之前,让我再指出有关文档注释块的两件事。
首先,您通常需要添加比标签提供的更多有关代码的信息。也许您想描述方法的用途,或者类如何适应更大的情况。将这些评论添加到评论块顶部的任意标签上方。 YUIDoc 会注意到它们并将它们包含在文档中。
/** The `Router` class is used for . . . @class Router @static */ var Router = {};
其次,您会很高兴地知道这些注释以及标记后编写的任何描述或消息都可以用 Markdown 编写,并且 YUIDoc 会将其转换为正确的 HTML。您甚至可以在注释中缩进示例代码块并获得语法突出显示!
示例
现在您已经了解了标签,让我们实际编写一些代码并记录下来。让我们创建一个 Store
模块,它包含两个类:Item
和 Cart
。每个 Item
实例都将是商店库存中的一种商品:它将具有名称、价格和数量。 Cart
实例可以将商品添加到购物车并计算购物车中商品的总价(含税)。它相当简单,但为我们提供了足够多的功能来使用我们讨论过的许多标签。我已将以下所有代码放入 store.js
中。
我们首先创建模块:
/** * This module contains classes for running a store. * @module Store */ var Store = Store || {};
现在,让我们创建一个“常量”:税率。
/** * `TAX_RATE` is stored as a percentage. Value is 13. * @property TAX_RATE * @static * @final * @type Number */ Store.TAX_RATE = 13;
这是 @type
的常量 (@final
) @property
数。请注意,我已经包含了 @static
:这是因为,出于某种原因,当我们生成此文件的文档时,YUIDoc 会将其显示为我们的 Item
类的属性:似乎 YUIDoc 不支持具有模块上的属性。我想我可以创建一个静态类来保存这个常量(以及如果我们进一步开发这个常量可能会出现的其他常量),但我这样保留它是为了提醒您:要充分利用像 YUIDoc 这样的工具,您可能必须改变您的编码方式。您必须决定这是否是您想要做的。
现在,对于 Item
类:
/** * @class Item * @constructor * @param name {String} Item name * @param price {Number} Item price * @param quantity {Number} Item quantity (the number available to buy) */ Store.Item = function (name, price, quantity) { /** * @property name * @type String */ this.name = name; /** * @property price * @type String */ this.price = price * 100; /** * @property quantity * @type Number */ this.quantity = quantity; /** * @property id * @type Number */ this.id = Store.Item._id++; Store.Item.list[this.id] = this; };
正如您所看到的,这个构造函数有三个参数。然后,我们还在描述构造函数内的三个属性。由于我们想要为每个 Item
提供一个唯一的 ID,因此我们需要存储一个静态(类级)属性来递增 ID,以及另一个静态属性,即通过 ID 跟踪 Item
的对象。
/** * `_id` is incremented when a new item is created, so every item has a unique ID * @property id * @type Number * @static * @private */ Store.Item._id = 1; /** * @property list * @static * @type Object */ Store.Item.list = {};
Cart
类怎么样?
/** * @class Cart * @constructor * @param name {String} Customer name */ Store.Cart = function (name) { /** * @property name * @type String */ this.name = name; /** * @property items * @type Object * @default {} */ this.items = {}; };
这里并没有什么新东西:请注意,我们声明 items
属性的默认(或初始)状态是一个空对象。
现在,方法。对于 addItem
,其中一个参数是可选的,因此我们将其声明为默认值 1。另外,请注意,我们创建了方法 @chainable
。
/** * Adds 1 or more of a given item to the cart, if the chosen quantity * is available. If not, none are added. * * @method addItem * @param item {Object} An `Item` Object * @param [quantity=1] {Number} The number of items to add to the cart * @chainable */ Store.Cart.prototype.addItem = function (item, quantity) { quantity = quantity || 1; if (item.quantity >= quantity) { this.items[item.id] = this.items[item.id] || 0; this.items[item.id] += quantity; item.quantity -= quantity; } return this; };
最后,我们希望能够返回总价,包括税费。请注意,我们以美分为单位进行价格计算,然后转换为美元并四舍五入到小数点后两位。
/** * @method total * @return {Number} tax-included total value of cart contents */ Store.Cart.prototype.total = function () { var subtotal, id; subtotal = 0; for (id in this.items) { if(this.items.hasOwnProperty(id)) { subtotal += Store.Item.list[id].price * this.items[id]; } } return parseFloat(((subtotal * (1 + Store.TAX_RATE / 100)) / 100).toFixed(2)); };
如果您想测试此代码,这里有一个简单的测试:
var apple, pear, book, desk, assertEquals; assertEquals = function (one, two, msg) { console.log(((one === two) ? "PASS : " : "FAIL : ") + msg); }; apple = new Store.Item('Granny Smith Apple', 1.00, 5); pear = new Store.Item('Barlett Pear', 2.00, 3); book = new Store.Item('On Writing Well', 15.99, 2); desk = new Store.Item('IKEA Gallant', 123.45, 1); cart = new Store.Cart('Andrew'); cart.addItem(apple, 1).addItem(book, 3).addItem(desk, 1); assertEquals(apple.quantity, 4, "adding 1 apple removes 1 from the item quantity"); assertEquals(book.quantity, 2, "trying to add more books than there are means none are added"); assertEquals(cart.total(), 140.63, "total price for 1 apple and 1 desk is 140.63");
生成文档
现在我们已经编写了代码和注释块,是时候生成文档了。
如果您通过 npm 全局安装了它,您将能够简单地运行 yuidoc {path to js}
。就我而言,就是这样
yuidoc .
现在,您将看到该文件夹中有一个 out
目录;打开out/index.html
,你会看到文档。以下是 Cart
类文档的部分内容:
配置输出
使用 YUIDoc 时可以设置多个配置选项。当然,您可以将它们设置为命令行标志,但我宁愿将它们设置在 JSON 配置文件中。在项目目录中,创建一个名为 yuidoc.json
的文件。首先,您可以设置一堆常规项目信息;这实际上并没有对输出产生太大影响,但最好记录一下它们:
{ "name": "Documenting JavaScript with YUIDoc", "description": "A tutorial about YUIDoc, for Nettuts+", "version": "1.0.0", "url": "https://code.tutsplus.com" }
然后,您可以设置许多实际选项。这里有一些有趣的;
-
linkNatives
:将其设置为“true”以将 String 或 Number 等原生类型链接到 MDN 文档。 -
outdir
:用这个重命名out
目录 -
paths
:使用此设置YUIDoc搜索JavaScript文件的路径。 -
exclude
:将其设置为您希望 YUIDoc 忽略的以逗号分隔的文件列表。
只要设置了 paths
选项,就可以运行 yuidoc -c yuidoc.json
并运行 YUIDoc。即使您没有设置 paths
并仅运行 yuidoc .
,YUIDoc 也会看到该配置文件并应用它。
这是我这个项目的总配置文件:
{ "name": "Documenting JavaScript with YUIDoc", "description": "A tutorial about YUIDoc, for Nettuts+", "version": "1.0.0", "url": "https://code.tutsplus.com", "options": { "linkNatives": "true", "outdir": "./docs", "paths": "." } }
评估
根据 YUIDoc 提供的标签,您可以看到它是为以传统 OOP 风格编写的 JavaScript 编写的,并且专门为 YUI 小部件等而设计(事实上,我遗漏了几个特定于 YUI 的标签) )。正因为如此,您可能会发现有几个标签对您来说没有多大用处。然后,你必须问自己是否愿意改变你的编码风格以更好地符合 YUIDoc“思考”的方式。但即使您不打算进行更改,我想您也会发现大多数 YUIDoc 标签都可以很好地适应。
对我来说,更大的问题是您是否喜欢将文档与代码内联。
我们上面写的示例代码有 120 行带注释,40 行不带注释。显然,这是超级简单的代码,几乎任何现实世界的例子都会更加平衡;然而,阅读这种散布的代码可能会很困难。就我个人而言,我认为我会给 YUIDoc 一个公平的试用:在接下来的几周内,我将在编写 JavaScript 时记录它(或者至少在它旁边)。我有兴趣看看它是否或如何影响我的编码风格和工作流程。
你知道这个惯例:喜欢或讨厌它,请在评论中告诉我!
了解更多
- YUIDoc 0.3.0 发布博文
- YUIDoc 主页
- 使用 YUIDoc
- YUIDoc 语法参考
- YUIDoc 主题
以上がYUIDoc を使用した JavaScript ドキュメントの文書化の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









この記事では、Microsoft Word で文書を再ページしたり印刷したりするときにメモリまたはディスク容量が不足する問題を解決する方法を紹介します。このエラーは通常、ユーザーが Word 文書を印刷しようとしたときに発生します。同様のエラーが発生した場合は、この記事に記載されている解決策を参照してください。この文書を再ページまたは印刷するにはメモリまたはディスク容量が不足しています。 Word エラー Microsoft Word の印刷エラー「文書を再ページまたは印刷するには、メモリまたはディスク容量が不足しています。」を解決する方法。 Microsoft Office を更新する メモリを大量に消費するアプリケーションを閉じる 通常使うプリンタを変更する Word をセーフ モードで起動する NorMal.dotm ファイルの名前を変更する Word ファイルを別のファイルとして保存する

395ワードなので495 この記事では、Word文書に赤線を追加する方法を紹介します。ドキュメントのレッドラインとは、ユーザーが変更を明確に確認できるようにドキュメントを変更することを指します。この機能は、複数の人が一緒にドキュメントを編集している場合に非常に重要です。レッドラインの意味 ドキュメントのマーク レッドラインとは、ドキュメントの変更、編集、または改訂を示すために赤い線または吹き出しを使用することを意味します。この用語は、印刷された文書に赤ペンを使用してマークを付ける習慣からインスピレーションを受けました。レッドライン コメントは、ドキュメントの編集時に作成者、編集者、レビュー担当者に推奨される変更を明確に示すなど、さまざまなシナリオで広く使用されています。法的合意や契約の変更や修正を提案する。 論文やプレゼンテーションなどに対して建設的な批評や提案を提供する。 Wの与え方

WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

近年、ネットワーク技術の発展により、私たちの生活はさまざまなデジタルツールやインターネットと切り離せないものになっています。文書を処理するとき、特に書面での処理では、Word 文書を使用することがよくあります。ただし、場合によっては、Word 文書内のハイパーリンクが開けないという難しい問題に遭遇することがあります。この問題については以下で説明します。まず、ハイパーリンクとは、Word 文書に追加された他の文書、Web ページ、ディレクトリ、ブックマークなどへのリンクを指すことを明確にする必要があります。これらのリンクをクリックすると、

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

Windows 11/10 コンピューターで Word 文書を開くときに空白ページの問題が発生した場合、状況を解決するために修復の実行が必要になる場合があります。この問題の原因はさまざまですが、最も一般的なものの 1 つはドキュメント自体の破損です。さらに、Office ファイルの破損によっても同様の状況が発生する可能性があります。したがって、この記事で提供されている修正が役に立つ可能性があります。いくつかのツールを使用して破損した Word 文書を修復したり、文書を別の形式に変換して再度開いたりすることができます。さらに、システム内の Office ソフトウェアを更新する必要があるかどうかを確認することも、この問題を解決する方法です。これらの簡単な手順に従うことで、Win で Word 文書を開くときに Word 文書が空白になる問題を修正できる可能性があります。

JavaScript と WebSocket を使用してリアルタイム オンライン注文システムを実装する方法の紹介: インターネットの普及とテクノロジーの進歩に伴い、ますます多くのレストランがオンライン注文サービスを提供し始めています。リアルタイムのオンライン注文システムを実装するには、JavaScript と WebSocket テクノロジを使用できます。 WebSocket は、TCP プロトコルをベースとした全二重通信プロトコルで、クライアントとサーバー間のリアルタイム双方向通信を実現します。リアルタイムオンラインオーダーシステムにおいて、ユーザーが料理を選択して注文するとき

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは
