欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何為你的JS項目添加智能提示與類型檢查詳解

 更新時間:2019年03月12日 10:44:26   作者:逆葵  
這篇文章主要給大家介紹了關(guān)于如何為你的JS項目添加智能提示與類型檢查的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者使用JS具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

最近在做項目代碼重構(gòu),其中有一個要求是為代碼添加智能提示和類型檢查。智能提示,英文為 IntelliSense,能為開發(fā)者提供代碼智能補全、懸浮提示、跳轉(zhuǎn)定義等功能,幫助其正確并且快速完成編碼。說起來,JavaScript 作為一門動態(tài)弱類型解釋型語言,變量聲明后可以更改類型,并且類型在運行時才能確定,由此容易產(chǎn)生大量代碼運行中才能發(fā)現(xiàn)的錯誤,相比 Java 等靜態(tài)類型語言,開發(fā)體驗上確實差了一截。更煩躁的是,智能提示就是依賴于靜態(tài)類型檢查的,所以在以前,指望 JavaScript 的智能提示完善度追上 Java 基本不可能。當(dāng)然,時代在進步,TypeScript 已經(jīng)問世許久,為 JavaScript 帶來了靜態(tài)類型檢查以及其他諸多特性。JavaScript 的智能提示也已有了解決方案。調(diào)研了一段時間后,下文以 VSCode 編輯器作為開發(fā)工具,介紹一下如何為 JavaScript 加上智能提示以及類型檢查。

基于 JSDoc

JSDoc 是目前最通用的 JavaScript API 文檔生成器,根據(jù)其語法編寫代碼注釋,可以十分方便地自動生成文檔。由于 JSDoc 能提供詳細的類型信息,其也被 VSCode 等編輯器接受應(yīng)用于智能提示。例如,可以使用 @type 標(biāo)簽來賦予部分聲明的 object 一個特殊類型:

/**
 * @type {{a: boolean, b: boolean, c: number}}
 */
var x = {a: true};
x.b = false;
x. // <- 由于 type 聲明,"x" 將被提示含有屬性 a,b 以及 c

JSDoc 最常見的使用是為函數(shù)的參數(shù)聲明類型,使用 @param 來完成:

/**
 * @param {string} param1 - 這里可以用于解釋參數(shù)含義
 */
function Foo(param1) {
 this.prop = param1; // param1 (以及 this.prop)均為 string 類型
}

為代碼添加 JSDoc 注釋使得閱讀和理解代碼更加方便(代碼交接時再也不用抓狂了,當(dāng)然前提是注釋寫得好),也保障了開發(fā)時的體驗并且降低了很多運行時才能發(fā)現(xiàn)的數(shù)據(jù)類型方面的 bug。VSCode 基本支持 JSDoc 的常見語法,具體使用可參見JSDoc support in JavaScript。

基于 TypeScript 類型聲明文件

除了使用 JSDoc 提前聲明類型,更為激進的做法是直接使用微軟開發(fā)的 TypeScript,為整個項目帶來完善的靜態(tài)類型檢查。當(dāng)然,對于老項目來說,改造的成本較為巨大(使用 Flow 也類似,要動的代碼太多,況且 Flow 爛尾了)。不過由于和 TypeScript 師出同門,VSCode 能夠直接讀取前者的類型聲明文件,來為 JavaScript 提供智能提示(實際上 JavaScript 的智能提示功能就是基于 TypeScript 團隊為 VSCode 提供的 JavaScript 語言服務(wù)開發(fā)的)。 TypeScript 的類型聲明文件以 .d.ts 為后綴,用于描述同名的 JavaScript 文件導(dǎo)出代碼的類型,功能上類似于 C 語言的 .h 頭文件。不嚴(yán)格地來說,ts 類型聲明文件就像用 TypeScript 語法將 JSDoc 的注釋重寫了一遍并提取到了單獨的文件中。VSCode 更是將二者作了融合,當(dāng)你二者混用的時候,可以直接在 JSDoc 的注釋中直接使用 ts 類型聲明文件中定義的 interface 和 class 等。直接使用官方提供的示意圖(圖中是 Visual Studio,不過無傷大雅):

對于自己的代碼,可以編寫對應(yīng)的 ts 類型聲明文件,而對于引用的第三方庫,社區(qū)同樣提供了解決方案:DefinitelyTyped 提供了常見的第三方庫的類型聲明文件。VSCode 有很多第三方庫已經(jīng)內(nèi)置類型聲明文件,自己下載的話直接使用 npm 即可:

# @types + 第三方庫名稱
npm i @types/express

關(guān)于 ts 類型聲明文件的語法等相關(guān)信息,參見官網(wǎng)介紹。

另外,在 VSCode 中,類型檢查并非默認開啟,這意味著即使你有詳盡的 JSDoc 注釋或 ts 類型聲明文件,依然可能在數(shù)據(jù)類型上栽跟頭。開啟方式為在項目根目錄下添加 jsconfig.json 文件,并設(shè)置 "checkJs": true,示例如下:

{
 "compilerOptions": {
  "checkJs": true
 },
 
 // 位于此目錄下的文件不進行靜態(tài)檢查和智能提示
 "exclude": [
  "node_modules",
  "**/node_modules/*"
 ]
}

總結(jié)

最后,無論是對老項目的改造或是新項目的開發(fā),使用以上的方式添加智能提示和類型檢查顯而易見會略微拖慢開發(fā)速度,但我們認為,與智能提示帶來的開發(fā)體驗、將很多可能在運行時才能發(fā)現(xiàn)的錯誤通過類型檢查前置解決、順手完成的詳細文檔以及重構(gòu)代碼時的信心相比,這點速度的犧牲是值得的。

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。

參考文檔:

相關(guān)文章

  • jQuery檢查元素存在性(推薦)

    jQuery檢查元素存在性(推薦)

    這篇文章主要介紹了JavaScript檢查元素存在性的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • 微信小程序跳轉(zhuǎn)到其他網(wǎng)頁(外部鏈接)的實現(xiàn)方法

    微信小程序跳轉(zhuǎn)到其他網(wǎng)頁(外部鏈接)的實現(xiàn)方法

    這篇文章主要介紹了微信小程序跳轉(zhuǎn)到其他網(wǎng)頁(外部鏈接)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • javaScript 動態(tài)訪問JSon元素示例代碼

    javaScript 動態(tài)訪問JSon元素示例代碼

    訪問JSon元素的方法有很多,在搜的時候會找到很多,本文使用javascript來動態(tài)訪問json元素,感興趣的朋友可以練練手哦
    2013-08-08
  • chatGPT前端流式輸出js實現(xiàn)三種方法—fetch、SSE、websocket

    chatGPT前端流式輸出js實現(xiàn)三種方法—fetch、SSE、websocket

    項目需要接入chatgpt提供的api,后端返回流式的字符,前端接收并實時顯示,在JavaScript中,使用Stream流通常指的是處理數(shù)據(jù)流的一種方式,它們允許數(shù)據(jù)被處理成塊,而不是一次性處理整個數(shù)據(jù)集,這對于處理大量數(shù)據(jù)或者來自網(wǎng)絡(luò)請求的數(shù)據(jù)非常有用,
    2024-07-07
  • 前端路由&webpack基礎(chǔ)配置詳解

    前端路由&webpack基礎(chǔ)配置詳解

    這篇文章主要介紹了前端路由&webpack基礎(chǔ)配置詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • D3.js 實現(xiàn)帶伸縮時間軸拓撲圖的示例代碼

    D3.js 實現(xiàn)帶伸縮時間軸拓撲圖的示例代碼

    這篇文章主要介紹了D3.js 實現(xiàn)帶伸縮時間軸拓撲圖的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • js貪吃蛇網(wǎng)頁版游戲特效代碼分享(挑戰(zhàn)十關(guān))

    js貪吃蛇網(wǎng)頁版游戲特效代碼分享(挑戰(zhàn)十關(guān))

    這篇文章主要為大家詳細介紹了js貪吃蛇網(wǎng)頁版游戲特效,游戲總共有十關(guān),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2015-08-08
  • js對象屬性名駝峰式轉(zhuǎn)下劃線的實例代碼

    js對象屬性名駝峰式轉(zhuǎn)下劃線的實例代碼

    這篇文章主要介紹了js對象屬性名駝峰式轉(zhuǎn)下劃線的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Javascript防止圖片拉伸的自適應(yīng)處理方法

    Javascript防止圖片拉伸的自適應(yīng)處理方法

    這篇文章主要給大家介紹了關(guān)于利用Javascript防止圖片拉伸的自適應(yīng)處理方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12
  • 全面解析Bootstrap彈窗的實現(xiàn)方法

    全面解析Bootstrap彈窗的實現(xiàn)方法

    這篇文章全面解析Bootstrap彈窗的實現(xiàn)方法,對其結(jié)構(gòu)進行詳細分析,感興趣的小伙伴們可以參考一下
    2015-12-12

最新評論