Deno是一个新兴的JavaScript和TypeScript运行环境,它使用V8引擎运行JavaScript代码,同时支持TypeScript编译。Deno内置了标准库并且支持ES模块。
然而,与Node.js不同,Deno没有npm这样的包管理器,这意味着如果你需要使用第三方模块,你必须手动下载并将其添加到你的项目中,这可能会变得很麻烦并导致代码可维护性的降低。在这篇文章中,我们将讨论如何解决Deno中第三方模块缺失的问题。
使用deno.land/x
Deno社区创建了一个名为deno.land/x的官方站点,允许开发者共享和使用Deno第三方模块。所有的第三方模块都存储在Github仓库中,并被deno.land/x代理提供服务。
要使用deno.land/x上托管的模块,需要在import语句中指定该模块在deno.land/x的完整路径。例如:
import { serve } from "https://deno.land/x/std@0.92.0/http/server.ts";
在这个例子中,我们从std模块导入了serve函数,版本号为0.92.0。
但是,有时deno.land/x访问会非常慢或者完全无法访问。为了解决这个问题,我们可以使用Velociraptor作为脚本管理器来自动下载和更新依赖项。
具体步骤如下:
- 安装Velociraptor:
deno install -qAf --unstable https://deno.land/x/velociraptor/velociraptor.ts
- 创建一个名为
scripts.yaml
的文件,指定你需要的模块及其版本信息。例如:
# scripts.yaml start: deno run main.ts deps: oak: https://deno.land/x/oak@4.0.0/mod.ts
在这个例子中,我们通过deno.land/x注册的oak模块的版本是4.0.0。在main.ts文件中使用时,只需导入该模块即可:
import { Application } from "oak";
- 运行Velociraptor脚本以安装所有依赖项:
vr deps
如果你的依赖项有更新,只需运行vr update
以更新依赖项即可。
使用DefinitelyTyped
如果一个第三方库没有Deno版本,但是已经存在TypeScript声明文件,那么我们可以使用DefinitelyTyped来解决该问题。DefinitelyTyped是一个GitHub仓库集合,提供通用JavaScript库的d.ts文件。
要使用DefinitelyTyped,我们可以在import语句中指定.d.ts文件的URL。例如:
import { Expression } from "https://cdn.skypack.dev/@babel/types";
在这个例子中,我们从DefinitelyTyped中导入了@babel/types模块的Expression类型。
使用转译
最后,如果以上两种方法都不适用,那么我们就需要使用转译工具将第三方模块转换为Deno可用的模块。常见的转译工具包括:
转译工具的使用方法因工具而异,请参阅它们各自的文档。在使用转译工具时,需要注意的是,它们可能会产生额外的负载和必须经过一定的修改才能正常运行。
总结
在Deno中解决第三方模块缺失问题
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/651b52b995b1f8cacd300ac9