deno在2025年新出了哪些api可供使用?

Deno 作为一个注重安全和标准合规性的 JavaScript/TypeScript 运行时,其 API 一直在持续迭代,尤其在对 Web 标准的支持、内置工具链和性能优化方面不断更新。以下是近年来 Deno 版本中新增的一些值得试用的 API(基于 Deno 1.30+ 至最新版本的主要更新):

1. Web API 增强

Deno 致力于对齐浏览器 Web API,近年来新增了多个实用的标准 API:

  • BroadcastChannel

    用于同一 origin 下不同上下文(如 Worker 与主线程)之间的通信,类似浏览器中的实现。

    typescript 复制代码
    // 主线程
    const channel = new BroadcastChannel("my-channel");
    channel.postMessage({ type: "greet", data: "Hello from main!" });
    
    // Worker 中
    const channel = new BroadcastChannel("my-channel");
    channel.onmessage = (e) => console.log(e.data); // 接收消息
  • TextEncoderStream/TextDecoderStream

    流式处理文本编码/解码,配合 Streams API 高效处理大文本:

    typescript 复制代码
    const encoder = new TextEncoderStream();
    const writer = encoder.writable.getWriter();
    writer.write("Hello, Deno!");
    writer.close();
    
    // 管道到可读流处理
    await encoder.readable.pipeTo(new WritableStream({
      write(chunk) { console.log(chunk); }
    }));

2. 内置模块新特性

Deno 的内置模块(如 deno/fsdeno/http)新增了多个实用 API:

  • Deno.FsFile 扩展方法
    deno/fs 模块的 FsFile 类新增了 readRange 方法,支持读取文件的指定字节范围:

    typescript 复制代码
    import { open } from "deno/fs";
    
    const file = await open("large-file.txt", { read: true });
    const buffer = new Uint8Array(1024);
    // 读取从偏移量 512 开始的 1024 字节
    const { nread } = await file.readRange(buffer, 512);
    console.log(new TextDecoder().decode(buffer.subarray(0, nread)));
    file.close();
  • deno/http 服务器增强

    支持 AbortSignal 终止请求,以及流式响应的更简洁写法:

    typescript 复制代码
    import { serve } from "deno/http";
    
    serve((req) => {
      // 10秒后终止未完成的请求
      const abortController = new AbortController();
      setTimeout(() => abortController.abort(), 10000);
    
      return new Response(
        (async function* () {
          yield "Streaming...\n";
          await new Promise(resolve => setTimeout(resolve, 1000));
          yield "Done!";
        })(),
        { signal: abortController.signal }
      );
    });

3. 安全与权限 API

Deno 以安全为核心,新增了更细粒度的权限控制 API:

  • Deno.permissions.queryAll

    批量查询当前进程的权限状态,替代逐个查询的繁琐操作:

    typescript 复制代码
    const permissions = await Deno.permissions.queryAll([
      { name: "read", path: "/data" },
      { name: "net", host: "api.example.com" }
    ]);
    console.log(permissions); // 输出各权限的状态(granted/denied)
  • Deno.permissions.revoke 增强

    支持撤销已授予的权限,并返回撤销结果:

    typescript 复制代码
    const { success } = await Deno.permissions.revoke({ name: "write", path: "/tmp" });
    if (success) console.log("写入权限已撤销");

4. 性能优化相关 API

  • Deno.memoryUsage()

    新增更详细的内存使用统计,包括堆内存、外部内存等:

    typescript 复制代码
    const memory = Deno.memoryUsage();
    console.log(`Heap used: ${memory.heapUsed / 1024 / 1024} MB`);
  • Deno.resolveDns

    直接解析 DNS 记录(支持 A、AAAA、CNAME 等类型),无需依赖第三方库:

    typescript 复制代码
    const records = await Deno.resolveDns("deno.land", "A");
    console.log("IPv4 地址:", records); // 输出 ["192.168.1.1", ...]

5. 实验性 API(需 --unstable 标志)

以下 API 仍在实验阶段,需通过 deno run --unstable 启用:

  • Deno.kv

    内置的键值存储,支持持久化、事务和原子操作,适合轻量级数据存储:

    typescript 复制代码
    const kv = await Deno.openKv();
    await kv.set(["user", 1], { name: "Alice", age: 30 });
    const { value } = await kv.get(["user", 1]);
    console.log(value); // { name: "Alice", age: 30 }
  • Deno.createHttpClient

    自定义 HTTP 客户端,支持代理、超时和 TLS 配置:

    typescript 复制代码
    const client = Deno.createHttpClient({
      proxy: "http://proxy.example.com:8080",
      timeout: 5000,
    });
    const res = await fetch("https://deno.land", { client });

试用建议

  • 实验性 API 可能会在后续版本中变更,生产环境慎用。
  • 查看 Deno 官方文档发布日志 获取最新 API 详情。
  • 通过 deno --version 确认当前版本,部分 API 仅在特定版本后可用。

这些新 API 进一步提升了 Deno 在开发效率、安全性和标准兼容性方面的优势,适合在工具开发、服务端应用等场景中尝试。

相关推荐
LinXunFeng8 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
乘风gg12 小时前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭12 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒12 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭12 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
DayDaydream13 小时前
7 天涨了 8000+ Star,Agent Reach 想给 AI 装上互联网眼睛
github
Hyyy14 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
Gatlin14 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
蝎子莱莱爱打怪14 小时前
XZLL-IM干货系列 03|消息 ID 设计:一个 UUID 搞不定的事,我用两个 ID 解决了
后端·面试·开源
Pedantic14 小时前
本地通知(Local Notifications)学习笔记
前端