Node.js 标准库 api 类型声明有误

这篇博客指出Node.js v15.9.0中fs.promises.watch方法的类型声明错误,并强调了返回值应为异步迭代器对象。作者揭示了DefinitelyTyped库中的问题及其修复进展。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Node.js 标准库 api 类型声明有误

在 Node.js v15.9.0 加入的 api fsPromises.watch(filename[, options]),在 @types/node/fs/promises 中的返回值类型有误。

参考文档 -> https://nodejs.org/docs/v15.9.0/api/fs.html#fs_fspromises_watch_filename_options

在该 api 最初被加入时,返回值类型就已经在文档中明确给出为一个对象的异步迭代器:

type returnType = AsyncIterable<{
  eventType: string;
  filename: string | Buffer;
}>;

desc

但在 @types/node/fs/promises 中为:

function watch(
        filename: PathLike,
        options:
            | (WatchOptions & {
                  encoding: 'buffer';
              })
            | 'buffer'
    ): AsyncIterable<Buffer>;
function watch(filename: PathLike, options?: WatchOptions | BufferEncoding): AsyncIterable<string>;
function watch(filename: PathLike, options: WatchOptions | string): AsyncIterable<string> | AsyncIterable<Buffer>;

这段代码第一次出现在这次 merge commit 中 -> DefinitelyTyped/c886d9bSimonSchick 搞错了这个 api 的返回值,相关 PR -> DefinitelyTyped#52775

这个问题将在 PR -> DefinitelyTyped#55033 中修复,正在等待 merge。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

高厉害

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值