利用Typings為Visual Studio Code實現(xiàn)智能提示功能
前言
相信大家都知道在IDE中代碼的智能提示幾乎都是標(biāo)配,雖然一些文本編輯器也有一些簡單的提示,但這是通過代碼片段提供的。功能上遠不能和IDE相比。不過最近興起的文本編輯器的新銳 Visual Studio Code 可以通過 Typings 來對 JavaScript 實現(xiàn)智能提示功能,對于一個文本編輯器來說,這點很難得。所以Visual Studio Code 特別適合用來編寫 JavaScript(Node.js)程序; 同時,如果我們需要編寫一些嘗試性的小代碼片段,例如:Lodash.js 某個函數(shù)的小Demo,因為我們不想研究一個函數(shù)的使用方式而去使用IDE新建一個項目,這時候Visual Studio Code 就是一個非常好的選擇,而且它同樣可以運行和調(diào)試 JavaScript 代碼(依賴于 Node.js),并且還包含非常方便的代碼提示功能。
從這點來說,我覺得Visual Studio Code 已經(jīng)算得上是一個精悍的小型IDE了。
通過NPM安裝Typings
通過 NPM 我們可以很容易的安裝 Typings ,在命令行中輸入:
npm install -g typings
安裝完成后,在命令行中輸入:
typings --version
看到版本信息就表示 typings 工具安裝完成了:
NPM是和Node.js一起安裝的,如果你想使用NPM的話,那么你應(yīng)該先安裝Node.js。
安裝相關(guān)提示信息文件
安裝完成后,我們需要安裝相應(yīng)的需要提示功能庫或者框架的類型信息文件,在這里我們新建一個文件夾 NodeSnippet,使用命令行進入到該目錄中,分別輸入下面兩個命令來安裝Node和Lodash的類型接口信息文件:
typings install dt~node --global --save typings install lodash --save
什么時候需要使用 --global
參數(shù):
- 如果安裝的包使用script標(biāo)記來引用(如jQuery)(也就是在瀏覽器中使用)
- 這個包是屬于環(huán)境的一部分(如node)時
- 該包沒有使用
--global
安裝失敗時
這時候我們可以看到我們的 NodeSnippet目錄中多了一些文件:
這些文件就是為我們提供提示信息的類型類型文件(使用TypeScript定義)。查看Typings是否支持某個庫或框架的智能提示,我們可以使用下面的命令:
typings search exampleName
啟用智能提示功能
通過兩種方式來啟動提示功能:
第一種是在需要進行只能提示的文件最上行增加提示信息文件所在目錄,格式如下:
/// <reference path="./typings/index.d.ts" />
第二種是在項目所在目錄(在這里是NodeSnippet文件夾中)增加一個名為jsconfig.json的空文件。
更多jsconfig.json文件的內(nèi)容可以參考:https://code.visualstudio.com/docs/languages/javascript
啟用提示功能后我們就可以非常愉快的使用Visual Studio Code 為我們提供的智能提示功能了。如下所示:
注意事項
Typings VS TSD
Typings是作為TSD的替代者而出現(xiàn)的,如果你已經(jīng)安裝了TSD,那么需要知道現(xiàn)在TSD已經(jīng)不推薦使用了。如果已經(jīng)安裝TSD請執(zhí)行下面的命令來移除它:
npm rm -g tsd
使用 CNPM
在國內(nèi)由于墻的原因,有時候使用NPM安裝模塊的速度上會很慢,這時候我們其實可以選擇國內(nèi)淘寶的NPM鏡像,使用下面的命令來進行安裝:
npm install -g cnpm --registry=https://registry.npm.taobao.org
安裝完成后使用cnpm來代替npm命令即可,例如下面安裝一個lodash模塊的示例:
cnpm install lodash
可以看到除了cnpm替代了npm其他的并沒有任何區(qū)別。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
- Visual Studio和Visual Studio Code之間有什么區(qū)別
- Visual Studio Code (vscode) 配置 C / C++ 環(huán)境的流程
- 使用 Visual Studio Code(VSCode)搭建簡單的Python+Django開發(fā)環(huán)境的方法步驟
- Visual Studio Code配置C、C++環(huán)境并編寫運行的方法
- 淺析Visual Studio Code斷點調(diào)試Vue
- Visual Studio Code 使用Git進行版本控制(圖文教程)
- 詳解使用Visual Studio Code對Node.js進行斷點調(diào)試
- 在Visual Studio Code中配置GO開發(fā)環(huán)境的詳細教程
- visual studio code 編譯運行html css js文件的教程
相關(guān)文章
Asp.Net 動態(tài)頁面轉(zhuǎn)靜態(tài)頁面主要代碼
關(guān)于在Asp.Net中動態(tài)頁面轉(zhuǎn)靜態(tài)頁面的方法網(wǎng)上比較多。結(jié)合實際的需求,我在網(wǎng)上找了一些源代碼,并作修改?,F(xiàn)在把修改后的代碼以及說明寫一下。2009-12-12Asp.net中將Word文件轉(zhuǎn)換成HTML的方法
這篇文章主要介紹了Asp.net中將Word文件轉(zhuǎn)換成HTML的方法,需要的朋友可以參考下2014-08-08在?.NET?中使用?FixedTimeEquals?應(yīng)對計時攻擊的例子
在計算機安全中,計時攻擊(Timing attack)是旁道攻擊 (Side-channel attack) 的一種,而旁道攻擊是根據(jù)計算機處理過程發(fā)出的信息進行分析,這篇文章主要介紹了在?.NET?中使用?FixedTimeEquals?應(yīng)對計時攻擊,需要的朋友可以參考下2022-06-06.NET Core 2.1中HttpClientFactory的最佳實踐記錄
這篇文章主要給大家介紹了關(guān)于.NET Core 2.1中HttpClientFactory的最佳實踐記錄,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用.net core2.1具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧2018-08-08ASP.NET Core在WebApi項目中使用MiniProfiler分析Entity Frame
這篇文章介紹了ASP.NET Core在WebApi項目中使用MiniProfiler分析Entity Framework Core的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-02-02.net Core 3.0 WebApi 創(chuàng)建Linux守護進程的方法
這篇文章主要介紹了.net Core 3.0 WebApi 創(chuàng)建Linux守護進程的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03