Tom*_*uer 12 typescript visual-studio-code deno
我正在查看 Deno 并发现其中一个非常优雅的入门示例:
import { serve } from "https://deno.land/x/std@v0.2.10/http/server.ts";
const s = serve("0.0.0.0:8000");
void async function main() {
  for await (const req of s) {
     req.respond({ body: new TextEncoder().encode("Hello World\n") });
  }
}()
我正在使用 VS Code 编写 Deno 脚本,但我不确定如何让编辑器知道导入函数的类型,例如serve. 我认为 Deno 对 IDE 的支持可能为时过早,但如果有解决方案或变通方法,我想了解一下。
我需要安装一个@types包或类似的东西吗?import或reference一些.d.ts声明文件?在使用serve本示例中的函数以及 Deno 中的任何导入脚本时,如何让 VS Code 提供代码完成建议并显示类型注释?
for*_*d04 15
安装denoland.vscode-deno扩展1。然后在特定项目中启用Deno,例如
<proj-root>/.vscode/settings.json:
{
  "deno.enable": true, // enables extension
  "deno.lint": true, // inline deno lint diagnostics, requires `deno.unstable`
  "deno.unstable": true // also provides unstable type declarations in VS Code
}
从v2.3.0开始,您还可以使用deno: Init向导2:

要集成 TS 工作区版本而不是 VS Code 内置版本,请查看链接的文档。
1 这个已经过时了。
2 注意:在一个新的空项目中,向导必须至少存在一个源文件才能正常工作。
.ts在 VS Code 中进行显式扩展"https://deno.land/std@0.56.0/http/server.ts"Deno.writeFile).ts模块的类型通过上述扩展,VS Code 允许.ts导入文件扩展名并将 URL 导入解析到本地磁盘缓存。编译器可以使用这些缓存的类型定义进行检查。最后,获取所有源并重新启动 TS 服务器/重新加载 VS Code:
{
  "deno.enable": true, // enables extension
  "deno.lint": true, // inline deno lint diagnostics, requires `deno.unstable`
  "deno.unstable": true // also provides unstable type declarations in VS Code
}
server.ts是标准库的一部分,它只是一个更严格维护的远程.ts模块集合,因此它也将被正确键入。
.js模块的类型Deno 提供了其他方法来引用.d.ts文件的.js文件。
// @deno-types="./foo.d.ts"
import * as foo from "./foo.js";
/// <reference types="./foo.d.ts" />
export const foo = "foo";
替代方案:Deno 可以X-TypeScript-Types从远程导入读取自定义HTTP 标头。
tsconfig.jsontsconfig.json项目中的
给定文件与 Deno 默认配置合并,例如:
{
  "compilerOptions": {
    // set a custom, deviant value
    "noImplicitAny": false // deno default is true
    // (this is just an example - use strong types, whenever possible)
  }
}
-c选项,因此 VS Code 和 Deno CLI 具有相同的编译器设置:
deno run -c ./tsconfig.json main.ts 
--unstable类型最简单的选择是在VS Code 中设置"deno.unstable": true( PR )settings.json并重新启动,请参阅tldr参考资料。
deno cache https://deno.land/std/http/server.ts # fetch and compile from URL 
# or main project file
deno cache <your main file>.ts # fetches all its dependencies
VS Code自动包含 deno.runtime.d.ts一个已存在的tsconfig.json(1)。
vscode-deno v1.26.0扩展必须明确启用通过"deno.enable": true在.vscode/settings.json项目(默认是false)。之前,默认值为true.
vscode-deno < 1.25.0在每种情况下(稳定和不稳定)安装 Deno 类型 - 请参阅"How to use --unstable types".
更新:vscode-deno工作得相当好。
以下是当前的解决方案:
tsconfig.json路径并将导入替换为http远程https依赖项的本地缓存位置(通常在$HOME/.deno/deps/http和下$HOME/.deno/deps/https)typings/文件夹。跑步deno --types > typings/deno.d.ts。Deno 将为核心 API 输出一个类型定义文件。import,请运行deno --prefetch your_file.ts以拉取所有依赖项。为了让事情变得更简单,我建议将所有远程依赖项保存在一个文件中deps.ts(并--prefetch在该文件上运行)并重新导出内容,以便项目中的其他文件可以使用 deps。| 归档时间: | 
 | 
| 查看次数: | 3454 次 | 
| 最近记录: |