3

Node + NPM 在 node_modules 中安装依赖项,所以如果我想调试一个依赖项,我可以去node_modules/some-pkg/some-file.js添加调试器语句、控制台日志等。

在 Deno 中,事情变得更加棘手,因为依赖项是从用户那里抽象出来的——它不再是普通的本地 JS 文件!例如,如果我有以下代码:

// main.js
import oaClient from 'https://cdn.pika.dev/oa-client';
const { createClient } = oaClient;
createClient();

它将输出堆栈跟踪:

nino@hp:~/learning/deno(master)$ deno run main.js 
error: Uncaught TypeError: Cannot read property 'paths' of undefined
  for (var path in specs.paths) {
                         ^
    at _default (https://cdn.pika.dev/-/oa-client@v0.7.1-hYTMbsju6JnnnXlCWvdN/dist=es2019/oa-client.js:428:26)
    at file:///home/nino/learning/deno/main.js:3:1

虽然我可以在https://cdn.pika.dev/-/oa-client@v0.7.1-hYTMbsju6JnnnXlCWvdN/dist=es2019/oa-client.js在线阅读代码,但我无法插入控制台日志或调试器陈述。

感谢deno info <the URL above>我可以获得依赖项缓存副本的本地路径,但我认为编辑文件不是~/.cache/deno正确的方法。

那么,Deno 调试依赖项的方法是什么?

4

2 回答 2

4

你可以试试deno debugger


$DENO_DIR修改全局缓存依赖项的另一种方法是使用环境变量下载项目目录中的包,这将影响您的所有项目。

DENO_DIR=$PWD/modules deno run main.js

现在你可以在$DENO_DIR/deps不影响其他项目的情况下修改里面的内容,完成后你可以使用:--reload再次下载所有依赖项。

要找出文件名,只需执行以下操作:

DENO_DIR=$PWD/modules deno info {package-url}
于 2020-05-20T17:14:48.170 回答
1

我找到了一种使用$DENO_DIR变量的方法,您的依赖项将与您的项目一起下载。

这将允许您在依赖项上设置断点,但它们正在转换为 JavaScript。在这个例子中它的工作方式不同。

设置DENO_DIR为您的项目根目录:

export DENO_DIR=$PWD

运行你的脚本。

deno run --allow-net app.ts

应用程序.ts

import { serve } from "https://deno.land/std/http/server.ts";
const s = serve({ port: 8000 });
console.log("http://localhost:8000/");
for await (const req of s) {
  req.respond({ body: "Hello World\n" });
}

http在此示例中,将在此处创建 lib的依赖文件:

$DENO_DIR/gen/https/deno.land/std/http/server.ts.js`

您现在可以使用 VS Code 创建断点。


如果您需要在 VS Code 上为 Deno 配置调试,请在此处遵循我的其他答案:

https://stackoverflow.com/a/61856774/3231778

于 2020-05-20T17:20:45.317 回答