簡體   English   中英

如何在 TypeScript 中覆蓋標准庫 function 的類型?

[英]How do I override type of a standard library function in TypeScript?

我正在開發一個 polyfill,它通過向 reviver 回調 function 添加可選的第三個參數來擴展JSON.parse() function 的行為。

polyfill 應該像這樣為最終用戶導入:

import 'my-polyfill';

JSON.parse()node_modules/typescript/lib/lib.es5.d.ts中定義如下:

// lib.es5.d.ts

interface JSON {

  // …

  parse(
    text: string,
    reviver?: (this: any, key: string, value: any) => any
  ): any;

  // …

}

如何覆蓋此定義,以便在安裝/導入 polyfill 時使用我的定義? 例如:

interface ContextType {
  // …
}

interface JSON {

  parse<Type = any>(
    text: string,
    reviver?: (
      key: string,
      value: any,
      context?: ContextType
    ) => any

  ): Type;

}

您可以創建聲明文件並將其命名為polyfill.d.ts等。 然后,您應該使用標准方式擴展全局類型,如下所示:

declare global {
  interface JSON {
    // Here, you should write your own implementation of `parse` function.
    parse(variable: string): void;
  }
}

export {};

export是 TypeScript 所必需的,您可以在答案及其評論中了解更多信息。

不要忘記,當您創建一個單獨的庫時,該文件應該存在於最終構建目錄中。 因此,當某些用戶安裝您的 package 並導入它時,文件polyfill.d.ts將由 TypeScript 自動應用。

我不確定您是否能夠制作具有自己功能的 TypeScript 傳輸聲明文件 ( .d.ts )。 為此,我們應該使用此處描述的一些 hack。 我們應該將文件命名為polyfill.ts而不是polyfill.d.ts並將其導入到庫的index.ts文件中,這樣它將被 TypeScript 導入並傳輸到構建目錄。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM