千鋒長沙前端培訓分享之使用jsDoc提升開發(fā)效率
作為前端開發(fā)者目前使用最廣泛的編程語言 JavaScript,也是有很多的缺點的!大家都直到 JavaScript 是一個弱類型的編程語言,這就造成了一問題,一個變量到底是什么類型的,只能到到程序運行的時候才只能確定!導致我們在寫碼的時候經(jīng)常遇到一些關(guān)于變量類型的錯誤!并且當我們使用 vscode 寫代碼的時候,使用別人提供的 api,代碼提示工具提示的非常好,而我們自己使用 js 編寫一些函數(shù)的時候,往往確發(fā)現(xiàn)代碼提示的不是很友好!今天我們來學習使用 jsDoc 來解決這個問題。先看下圖:
我們使用vscode 編寫函數(shù)過程中,函數(shù)的形參是一個字符串,我們在寫代碼的時候vscode 并不知道形參的類型,導致我們在寫代碼的時候并不會得到很好的代碼提示!
jsDoc
這個時候我們可以使用jsDoc來解決這個問題,vscode內(nèi)置了jsDoc,我們只需要在函數(shù)上面輸入/** 然后就會提示,然后直接按回車就好!
如下圖:
此時,我們再使用username
就能看到所有的方法就能提示出來了,因為我們jsDoc生成的注釋里面,執(zhí)行的username參數(shù)的類型。
什么是jsDoc
jsDoc,顧名思義,jsDoc是一個用于JavaScript的API文檔生成器,類似于Javadoc或phpDocumentor。他可以將文檔注釋直接添加到源代碼中,就在代碼本身旁邊。JSDoc工具可以將掃描源代碼并為您成一個HTML文檔網(wǎng)站。
JSDoc注釋通常應(yīng)該放在代碼被記錄之前。為了被JSDoc解析器識別,每個注釋必須以/**序列開頭!
最簡單的文檔描述
/** 這是foo 函數(shù)的描述信息. */
function foo() {
}
添加文檔描述很簡單,只需在文檔注釋中鍵入所需的內(nèi)容就可以。
也可以使用特殊的JSDoc標簽來提供更多信息。例如,如果函數(shù)是類的構(gòu)造函數(shù),則可以通過添加@constructor標記來指示這一點。
/**
* 表示一本書
* @constructor
*/
function Book(title, author) {
}
使用jsDoc標簽添加更多信息
/**
* 表示一本書
* @constructor
* @param {string} title - 書的標題.
* @param {string} author - 書的作者.
*/
function Book(title, author) {
}
param {string} title
這句話相當于給參數(shù)title增加了一個string類型!
這個類型是可以 string 、number、 boolean等基礎(chǔ)數(shù)據(jù)類型!也可以是是個復(fù)雜數(shù)據(jù)類型。
param {object} title
/**
*
* @param {Object} book
* @param {string} book.title
* @param {string} book.author
*/
function buyBook(book) {
}
這樣我們在使用book的使用就會提示出所有的屬性和方法!
不過這樣我們在每個函數(shù)內(nèi)部都使用到了book的時候,都得在注釋里面寫三句話,使用起來就比較麻煩!
@typedef和@property
我們可以使用@typedef和@property 定義一個類型,然后在其他地方使用
@return
當我們使用Book這個構(gòu)造函數(shù)的時候,就會提示如下內(nèi)容,并且在編寫代碼的時候vscode能自動識別title和author的類型,并且能提示對應(yīng)的類型的方法!提示的最后面有個 :Book,這個提示是vscode自動識別出來函數(shù)的返回值!我們也可以使用@return 指定返回值的類型!
該標簽就是用來指定函數(shù)的返回值,用法與@param類型,并且基本上這兩個都會同時出現(xiàn),與@param的區(qū)別在于,因為@return只會有一個,所以不會像前者一樣還需要指定參數(shù)名。
/**
* @return {number} 描述
*/
function test () { }
Promise 類型的返回值處理
// 函數(shù)返回 Promise 實例的情況可以這么指定類型
/**
* @return {Promise<number>}
*/
function testPromise () {
return new Promise((res) => {
res(1)
})
}
生成一個網(wǎng)站
使用jsDoc編寫注釋,也可以生成一個網(wǎng)站,網(wǎng)站內(nèi)容是提取注釋的內(nèi)容
先全局安裝jsDoc:
npm install jsdoc -g
然后輸入命令:
jsdoc book.js
使用jsDoc來注釋代碼,帶來的好處就是,維護者能夠很清晰的看出函數(shù)的作用和參數(shù)的類型,做到代碼即文檔。可以不用寫那么多的注釋!在日常開發(fā)時,結(jié)合vscode的自動補全、動態(tài)提示功能,一定能讓我們開發(fā)效率大大提升!

猜你喜歡LIKE
最新文章NEW
相關(guān)推薦HOT
更多>>熱門推薦
零基礎(chǔ)必看的前端HTML+CSS教程
沸Java培訓新手實戰(zhàn)必備!單機版坦克大戰(zhàn)分步實現(xiàn)項目源碼
熱3種Javascript圖片預(yù)加載的方法詳解
熱長沙前端培訓:一招教你用vue3+canvas實現(xiàn)坦克大戰(zhàn)
新互聯(lián)網(wǎng)涼了?參加長沙Java培訓能找到工作嗎?
長沙Java培訓實戰(zhàn)項目,出游咨詢訂票系統(tǒng)開發(fā)流程
不參加長沙Java培訓能學會Java嗎?2022Java技能學習路線圖
千鋒長沙Java培訓分享之怎么學習Java集合?
千鋒長沙前端培訓分享之JavaScript面向?qū)ο缶幊趟枷朐斀?/p>
千鋒長沙前端培訓分享之web前端的回流和重繪
千鋒長沙前端培訓分享之3種Javascript圖片預(yù)加載的方法詳解
千鋒長沙前端培訓分享之利用Jest測試React組件
千鋒長沙前端培訓分享之JavaScript中Slice的用例
千鋒長沙java培訓分享之Socket編程
技術(shù)干貨







快速通道 更多>>
-
課程介紹
點擊獲取大綱 -
就業(yè)前景
查看就業(yè)薪資 -
學習費用
了解課程價格 -
優(yōu)惠活動
領(lǐng)取優(yōu)惠券 -
學習資源
領(lǐng)3000G教程 -
師資團隊
了解師資團隊 -
實戰(zhàn)項目
獲取項目源碼 -
開班地區(qū)
查看來校路線