利用Typings为Visual Studio Code实现智能提示功能

 更新时间:2017年02月04日 11:20:35   作者:gyzhao  
最近在学习Node.js及ThinkJS这个框架,用vscode作为开发环境。默认情况下vscode对ThinkJS的代码提示并不好,所以研究了一下,原来可以同通过Typings来让vscode拥有强大的智能代码提示功能。下面本文就介绍了如何利用Typings为Visual Studio Code实现智能提示功能。

前言

相信大家都知道在IDE中代码的智能提示几乎都是标配,虽然一些文本编辑器也有一些简单的提示,但这是通过代码片段提供的。功能上远不能和IDE相比。不过最近兴起的文本编辑器的新锐 Visual Studio Code 可以通过 Typings 来对 JavaScript 实现智能提示功能,对于一个文本编辑器来说,这点很难得。所以Visual Studio Code 特别适合用来编写 JavaScript(Node.js)程序; 同时,如果我们需要编写一些尝试性的小代码片段,例如:Lodash.js 某个函数的小Demo,因为我们不想研究一个函数的使用方式而去使用IDE新建一个项目,这时候Visual Studio Code 就是一个非常好的选择,而且它同样可以运行和调试 JavaScript 代码(依赖于 Node.js),并且还包含非常方便的代码提示功能。

从这点来说,我觉得Visual Studio Code 已经算得上是一个精悍的小型IDE了。

通过NPM安装Typings

通过 NPM 我们可以很容易的安装 Typings ,在命令行中输入:

npm install -g typings

安装完成后,在命令行中输入:

typings --version

看到版本信息就表示 typings 工具安装完成了:

NPM是和Node.js一起安装的,如果你想使用NPM的话,那么你应该先安装Node.js。

安装相关提示信息文件

安装完成后,我们需要安装相应的需要提示功能库或者框架的类型信息文件,在这里我们新建一个文件夹 NodeSnippet,使用命令行进入到该目录中,分别输入下面两个命令来安装Node和Lodash的类型接口信息文件:

typings install dt~node --global --save
typings install lodash --save

什么时候需要使用 --global 参数:

  1. 如果安装的包使用script标记来引用(如jQuery)(也就是在浏览器中使用)
  2. 这个包是属于环境的一部分(如node)时
  3. 该包没有使用 --global 安装失败时

这时候我们可以看到我们的 NodeSnippet目录中多了一些文件:

这些文件就是为我们提供提示信息的类型类型文件(使用TypeScript定义)。查看Typings是否支持某个库或框架的智能提示,我们可以使用下面的命令:

typings search exampleName

启用智能提示功能

通过两种方式来启动提示功能:

第一种是在需要进行只能提示的文件最上行增加提示信息文件所在目录,格式如下:

/// <reference path="./typings/index.d.ts" />

第二种是在项目所在目录(在这里是NodeSnippet文件夹中)增加一个名为jsconfig.json的空文件。

更多jsconfig.json文件的内容可以参考:https://code.visualstudio.com/docs/languages/javascript

启用提示功能后我们就可以非常愉快的使用Visual Studio Code 为我们提供的智能提示功能了。如下所示:

注意事项

Typings VS TSD

Typings是作为TSD的替代者而出现的,如果你已经安装了TSD,那么需要知道现在TSD已经不推荐使用了。如果已经安装TSD请执行下面的命令来移除它:

 npm rm -g tsd

使用 CNPM

在国内由于墙的原因,有时候使用NPM安装模块的速度上会很慢,这时候我们其实可以选择国内淘宝的NPM镜像,使用下面的命令来进行安装:

npm install -g cnpm --registry=https://registry.npm.taobao.org

安装完成后使用cnpm来代替npm命令即可,例如下面安装一个lodash模块的示例:

cnpm install lodash 

可以看到除了cnpm替代了npm其他的并没有任何区别。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

相关文章

  • Asp.Net 动态页面转静态页面主要代码

    Asp.Net 动态页面转静态页面主要代码

    关于在Asp.Net中动态页面转静态页面的方法网上比较多。结合实际的需求,我在网上找了一些源代码,并作修改。现在把修改后的代码以及说明写一下。
    2009-12-12
  • ASP.NET 2.0中的页面输出缓存

    ASP.NET 2.0中的页面输出缓存

    ASP.NET 2.0中的页面输出缓存...
    2006-09-09
  • ASP.NET 多次提交的解决办法2

    ASP.NET 多次提交的解决办法2

    对“添加”、“提交”、“保存”、“更新”等按钮需要对数据库进行写操作的按钮,一定要在页面初始化时加载脚本,防止多次重复点击
    2008-12-12
  • Asp.net中将Word文件转换成HTML的方法

    Asp.net中将Word文件转换成HTML的方法

    这篇文章主要介绍了Asp.net中将Word文件转换成HTML的方法,需要的朋友可以参考下
    2014-08-08
  • asp.net使用ashx生成图形验证码的方法示例

    asp.net使用ashx生成图形验证码的方法示例

    这篇文章主要介绍了asp.net使用ashx生成图形验证码的方法,结合实例形式分析了asp.net生成图形验证码的步骤、实现方法与相关注意事项,需要的朋友可以参考下
    2017-07-07
  • 在 .NET 中使用 FixedTimeEquals 应对计时攻击的例子

    在 .NET 中使用 FixedTimeEquals 应对计时攻击的例子

    在计算机安全中,计时攻击(Timing attack)是旁道攻击 (Side-channel attack) 的一种,而旁道攻击是根据计算机处理过程发出的信息进行分析,这篇文章主要介绍了在 .NET 中使用 FixedTimeEquals 应对计时攻击,需要的朋友可以参考下
    2022-06-06
  • .NET Core 2.1中HttpClientFactory的最佳实践记录

    .NET Core 2.1中HttpClientFactory的最佳实践记录

    这篇文章主要给大家介绍了关于.NET Core 2.1中HttpClientFactory的最佳实践记录,文中通过示例代码介绍的非常详细,对大家学习或者使用.net core2.1具有一定的参考学习价值,需要的朋友们下面来一起看看吧
    2018-08-08
  • ASP.NET Core在WebApi项目中使用MiniProfiler分析Entity Framework Core

    ASP.NET Core在WebApi项目中使用MiniProfiler分析Entity Frame

    这篇文章介绍了ASP.NET Core在WebApi项目中使用MiniProfiler分析Entity Framework Core的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-02-02
  • asp.net 程序优化精选

    asp.net 程序优化精选

    对于asp.net需要注意的一些事项,可以提高你的程序运行效率。
    2009-04-04
  • .net Core 3.0 WebApi 创建Linux守护进程的方法

    .net Core 3.0 WebApi 创建Linux守护进程的方法

    这篇文章主要介绍了.net Core 3.0 WebApi 创建Linux守护进程的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03

最新评论