JSDoc那些事

幾天工作上需要文檔化一些Javascript東西,所以在找一些JS文檔化工具,以下分析幾種工具。

1.JSDoc-toolkit

? 一開始還想用這個工具,但后來在解析生成文檔時候,出現了很嚴重的錯誤,還存在其他問題。

? ? 問題1:閉包存在時候,解析出錯(很嚴重) ,導致幾乎就不能用來做JS文檔化。

? ? 問題2:在Javascript部分,注釋怎么寫都不對,感覺這個工具使用起來很困難

? ? 問題3:如果是靜態函數或prototype設置函數,就會出問題,warning錯誤,然后生成的文檔很怪異

? 之所以會出現上面種種問題,關鍵點就是解析時需源代碼,這問題太嚴重了。

? 也是解析出錯這個原因,導致最后不得不舍棄這個工具。

? ? 建議:JavaDoc可以用,感覺這種工具更多是給Java用的

2.JSDoc

? 很類似JSDoc-toolkit ,注釋方式幾乎一樣,沒什么差別,同樣解析需源代碼(又不得不舍棄)。

? PS:因為不同的人寫js的方式千奇百怪,不能強制js的寫法,最好是只需要規范注釋寫法,文檔生成工具從注釋獲取信息來生成文檔。

3.YUIDoc

? 只解析YUIdoc的注釋塊,不解析源代碼(令人振奮的消息,可以支持多種語言,產生錯誤 的可能將大大減小),只需要安裝nodejs,在命令行安裝YUIDoc就可用了,使用起來也非常簡單。但是,這個工具還是基于面向對象語言來做文檔化的,所以在給JS使用時,還是有些怪異,不過這些問題是可以忍受的。

?

總之,一個好的文檔化工具,最好是有兩鐘模板,一個給函數式語言使用,一種給面向對象語言使用,兩者雜糅起來挺不好的。另外最好是簡單易用,特別不要出現解析出錯,一出現解析出錯,相信再好用再華麗也沒有人用。

?

本文轉自 海角在眼前 博客園博客,原文鏈接:?http://www.cnblogs.com/lovesong/p/3267047.html? ,如需轉載請自行聯系原作者


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/256852.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/256852.shtml
英文地址,請注明出處:http://en.pswp.cn/news/256852.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

onBlur事件與onfocus事件(js)

onFocus事件就是當光標落在文本框中時發生的事件。 onBlur事件是光標失去焦點時發生的事件。 可以編如下例子 1.html <HTML> <HEAD> <TITLE>使用onBlur事件處理程序</TITLE> </HEAD> <BODY BGCOLOR"lavender"> <FORM name&qu…

談論Java原子變量和同步的效率 -- 顛覆你的生活

我們認為&#xff0c;由于思維定式原子變量總是比同步運行的速度更快&#xff0c;我想是這樣也已經&#xff0c;直到實現了ID在第一次測試過程生成器不具有在這樣一個迷迷糊糊的東西。測試代碼&#xff1a; import java.util.ArrayList; import java.util.List; import java.ut…

總結從linux - windows 上(GCC與MSVC 2015) 移植C或者C++代碼時候遇到的編譯和鏈接問題

解決辦法和修改辦法的總體思想 1、在代碼的語義和功能不變的情況下&#xff0c;進行c->c的轉變&#xff0c;消除編譯器的跨平臺編譯報錯問題&#xff1b; 2、遇到編譯問題&#xff0c;先看編譯器提示信息&#xff0c;然后逐個排查和定位&#xff0c;去解決問題。 1、當遇到…

1 week110的zookeeper的安裝 + zookeeper提供少量數據的存儲

下面是在weekend110上的zookeeper的安裝 在此之前&#xff0c;先進行快照備份。 在這里&#xff0c;為了后續的zookeeper配置需要&#xff0c;在/home/hadoop/下&#xff0c;新建data目錄&#xff0c;再新建zookeeper-3.4.6目錄&#xff0c;再新建zkdata目錄。 默認情況下&…

學習筆記(46):Python實戰編程-protocol

立即學習:https://edu.csdn.net/course/play/19711/343108?utm_sourceblogtoedu 1.protocol協議&#xff1a;主要用于窗體關閉監聽&#xff0c;通過這個協議可以在窗體關閉前提示是否真的要關閉&#xff0c;這樣可以防止用戶誤觸導致數據的丟失 2.關鍵代碼 #----------------…

linux yum命令詳解

yum&#xff08;全稱為 Yellow dog Updater, Modified&#xff09;是一個在Fedora和RedHat以及SUSE中的Shell前端軟件包管理器。基於RPM包管理&#xff0c;能夠從指定的服務器自動下載RPM包并且安裝&#xff0c;可以自動處理依賴性關系&#xff0c;并且一次安裝所有依賴的軟體包…

linux配置Java環境變量(詳細)

一. 解壓安裝jdk 在shell終端下進入jdk-6u14-linux-i586.bin文件所在目錄&#xff0c; 執行命令 ./jdk-6u14-linux-i586.bin 這時會出現一段協議&#xff0c;連繼敲回車&#xff0c;當詢問是否同意的時候&#xff0c;輸入yes&#xff0c;回車。之后會在當前目錄下生成一個jdk1.…

在c++代碼中關閉和啟動另外一個pid進程號,共享內存數據使用

char * of_program_name "./AB"; 1、 pid getPidFromName(of_program_name); if (pid > 0) { ERROR("AB process still exispid %d\n", pid); if (kill(pid, SIGKILL)) //殺死進程 { fprintf(std…

提速XP操作系統

1、加速網上鄰居 在Windows XP中訪問網上鄰居是相當惱人的&#xff0c;系統會搜索自己的共享目錄和可作為網絡共享的打印機以及計劃任務中和網絡相關的計劃任務&#xff0c;然后才顯示出來&#xff0c;顯然這樣速度就會比Windows 9x中慢很多。其實這些功能我們并沒有使用上&…

學習筆記(47):Python實戰編程-pack布局

立即學習:https://edu.csdn.net/course/play/19711/343109?utm_sourceblogtoedu pack布局&#xff1a; 1&#xff09;最常用的布局&#xff0c;順序排列布局方法 2&#xff09;完成了簡單的組件位置碼放&#xff0c;但如果內部布局處理機制跟不上的話&#xff0c;也可能會達…

ASP.NET Web API 應用教程(一) ——數據流使用

相信已經有很多文章來介紹ASP.Net Web API 技術&#xff0c;本系列文章主要介紹如何使用數據流&#xff0c;HTTPS&#xff0c;以及可擴展的Web API 方面的技術&#xff0c;系列文章主要有三篇內容。 主要內容如下&#xff1a; I 數據流 II 使用HTTPS III 可擴展的Web API 文檔…

JAVA類的構造方法

1,構造方法沒有返回類型, 定義: []public] 方法名() {} 2,一個構造方法如果想調用同一類中的另一個構造方法,只能調用一個,并且要放在構造方法第一行 3,用this調用,如 1 public person(int i, int j) { 2 this(); //調用另一個構造方法,且放在第一行 3 } 轉載于:https://www…

將字符串和數字合并動態寫入

sprintf(tmpTime, "/media/AIlog/%02d_%02d_%.txt",100,200);

windows安裝64位Pygame方法

因為官方網站http://www.pygame.org/download.shtml并沒有提供64位的pygame&#xff0c;所以要找其他網站制作的64位安裝文件。 如果你已經在你的64位開發環境中安裝了32位的pygame&#xff0c; 那么在導入pygame包的時候&#xff0c; 會有提示&#xff1a; ImportError: DLL l…

學習筆記(48):Python實戰編程-grid布局

立即學習:https://edu.csdn.net/course/play/19711/343110?utm_sourceblogtoedu grid布局&#xff1a;根據表結構進行的布局&#xff0c;索引為0行0列開始&#xff0c;最具代表性的即使電腦計算器的數字和符號按鍵布局 組件.grid(row 行索引號 &#xff0c; column 列索引號…

為什么“三次握手,四次揮手”?

前言&#xff1a; 如果你說你懂IT,你懂計算機網絡&#xff0c;那么你會怎么解釋“三次握手&#xff0c;四次揮手”&#xff1f; ---------------- 1.TCP報文段首部格式&#xff1a; 2.TCP建立連接圖 -------------------------------------------- 符號說明 seq:"sequance…

學習筆記(49):Python實戰編程-place布局

立即學習:https://edu.csdn.net/course/play/19711/343111?utm_sourceblogtoedu 1.place布局&#xff1a; 1&#xff09;最靈活的布局方式&#xff0c;是根據坐標點來進行組件的位置布局的 2&#xff09;確定坐標點后&#xff0c;組件從坐標點開始展開&#xff0c;即以指定…

cobbler基礎安裝

epel源安裝rpm -ivh epel-release-6-8.noarch.rpmyum -y install cobbler httpd rsync tftp-server xinetd dhcp cobbler-web koan pykickstart* fence-agents* debmirror syslinux$$$$$$$$$$$啟動cobbler服務/etc/init.d/cobblerd start$$$$$$$$啟動httpd服務/etc/init.d/http…

[ActionScript 3.0] NetConnection建立客戶端與服務器的雙向連接

一個客戶端與服務器之間的接口測試的工具 <?xml version"1.0" encoding"utf-8"?> <!--- - - - - - - - - - - - - - - - - - - - - - - - - * author:Frost.Yen * E-mail:871979853qq.com * create:2016-7-13上午12:10:20 - - - - - - - - - - …

C++ share_prt 簡單設計和實現

C 比較煩惱的是內存的管理&#xff0c;new是簡單&#xff0c;不夠&#xff0c;delete偶爾就會忘記。或者說&#xff0c;出現&#xff0c;多個對象共享多一個內存&#xff0c;一個delete以后&#xff0c;導致其他也不能用的不良情況&#xff0c;所以就跑出了一個智能指針來進行管…