如何编写一个d.ts文件_.d.ts怎么写-程序员宅基地

技术标签: 技术  js  typescript  ts  

如何编写一个d.ts文件

.d.ts文件是ts模块,变量一系列的申明文件。比如要使用react,就需要安装"@types/react",之后还会有提示。自定义全局声明文件,往往在根目录新建一个typings.d.ts文件

全局类型

  • 变量

有一个全局变量,那对应的d.ts文件里面这样写。如果一个.ts、.d.ts文件如果没有用到import或者export语法的话,那么最顶层声明的变量就是全局变量。

declare var aaa:number
declare const pi:number = Math.PI
  • 函数

由上面的全局变量的写法我们很自然的推断出一个全局函数的写法如下:

decalre function getName(id:number|string):string
  • class

当然除了变量和函数外,我们还有类(class)。

declare class Person {

    static maxAge: number //静态变量
    static getMaxAge(): number //静态方法

    constructor(name: string, age: number)  //构造函数
    getName(id: number): string 
}
  • 对象

对象的话,使用namespace命名空间来声明

declare namespace common{
    
}
// 还可以嵌套
declare namespace OOO{
    var aaa: number | string
    // ...
    namespace O2{
        let b:number
    }
}
  • menu

使用 declare enum 定义的枚举类型也称作外部枚举

declare enum Directions {
    Up,
    Down,
    Left,
    Right
}
  • interface 和 type

除了全局变量之外,可能有一些类型我们也希望能暴露出来。在类型声明文件中,我们可以直接使用 interface 或 type 来声明一个全局的接口或类型

interface AjaxSettings {
    method?: 'GET' | 'POST'
    data?: any;
}

暴露在最外层的 interface 或 type 会作为全局类型作用于整个项目中,我们应该尽可能的减少全局变量或全局类型的数量。故最好将他们放到 namespace

declare namespace jQuery {
    interface AjaxSettings {
        method?: 'GET' | 'POST'
        data?: any;
    }
    function ajax(url: string, settings?: AjaxSettings): void;
}
  • 混合类型

有时候有些值既是函数又是class又是对象的复杂对象。比如我们常用的jquery有各种用法:

new $()
$.ajax()
$()

那么如下声明:

declare function $2(s:string): void

declare namespace $2{
    let aaa:number
}
  • 模块化(CommonJS)

除了上面的全局的方式,我们有时候还是通过require的方式引入模块化的代码。如果要像如下引入代码:

let util = require('util')
util.setTitle("hello")

对应写法如下:

declare module "util" {
  export let a: number
  export function setTitle(title: string): void;
  export namespace c{
    let cd: string
  }
}
  • export

npm 包的声明文件与全局变量的声明文件有很大区别。在 npm 包的声明文件中,使用 declare 不再会声明一个全局变量,而只会在当前文件中声明一个局部变量。只有在声明文件中使用 export 导出,然后在使用方 import 导入后,才会应用到这些类型声明

export 的语法与普通的 ts 中的语法类似,区别仅在于声明文件中禁止定义具体的实现

declare const name: string;
declare function getName(): string;
declare class Animal {
    constructor(name: string);
    sayHi(): string;
}
declare enum Directions {
    Up,
    Down,
    Left,
    Right
}
interface Options {
    data: any;
}

export { name, getName, Animal, Directions, Options };
  • UMD

有一种代码,既可以通过全局变量访问到,也可以通过require的方式访问到。比如我们最常见的jquery:

declare namespace UUU{
    let a:number
}
 
declare module "UUU" {
    export =UUU
}
  • 定义全局的

使用 declare global 可以在 npm 包或者 UMD 库的声明文件中扩展全局变量的类型

declare global {
    interface String {
        prependHello(): string;
    }
}
  • 其他

有时候我们扩展了一些内置对象。比如我们给Date增加了一个format的实例方法:

let d = new Date()
d.format = function (f: string): string {
  return this.getFullYear().toString()
}

那么声明文件应该这么写:

interface Date {
    format(f: string): string
}

参考文献

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_42036203/article/details/98847158

智能推荐

chatgpt中的强化学习 PPO_chatgpt使用的强化学习-程序员宅基地

文章浏览阅读3.4k次。本该到此结束,但是上述实现的时候其实是把生成的每一步的奖励都使用统一的句子级reward,但该代码其实也额外按照每个token来计算奖励值的,为了获取每个token的奖励,我们在生成模型的隐层表示上,多加一个线性层,映射到一维,作为每个状态的预测奖励值。类似的,在文本生成中我们也可以用蒙特卡洛方法来估计一个模型的状态价值。假如我们只采样到了s1和s2,没有采样到s3,由于7和3都是正向奖励,s1和s2的训练后生成的概率都会变大,且s1的概率变的更大,这看似合理,但是s3是未参与训练的,它的概率反而减小了。_chatgpt使用的强化学习

获取不规则多边形中心点_truf计算重心-程序员宅基地

文章浏览阅读433次,点赞10次,收藏8次。尝试了3种方法,都失败了!_truf计算重心

HDU 1950最长上升子序列 学习nlogn_poj 1631 hdu 1950为啥是最长上升子序列-程序员宅基地

文章浏览阅读406次。学习LIS_poj 1631 hdu 1950为啥是最长上升子序列

kubernetes===》二进制安装_sed -ie 's#image.*#image: ${ epic_image_fullname }-程序员宅基地

文章浏览阅读550次。一、节点规划主机名称IP域名解析k8s-m-01192.168.12.51m1k8s-m-02192.168.12.52m2k8s-m-03192.168.12.53m3k8s-n-01192.168.12.54n1k8s-n-02192.168.12.55n2k8s-m-vip192.168.12.56vip二、插件规划#1.master节点规划kube-apiserverkube-controller-manage_sed -ie 's#image.*#image: ${ epic_image_fullname }#g

SpringBoot缓存注解的使用-程序员宅基地

文章浏览阅读4.6k次,点赞2次,收藏17次。在springboot中使用缓存注解很简单,首先就只需要在依赖中引入spring-boot-starter-cache依赖,然后在application类中使用@EnableCaching注解开启缓存,然后在方法上根据需要使用具体的缓存注解即可。_springboot缓存注解

SAP中如何查询未审批采购订单_sap查询未处理采购申请-程序员宅基地

文章浏览阅读2.8k次。在MM采购订单审批应用中,作为订单的管理者(采购)或订单的审批者(相关领导)需要能主动的进行待审批订单的查询和处理。因此,如何查询未审批采购订单是一个很基础很实用的功能。下面一起来看看吧。在事务ME2N中先按下图方式进行选择;通过对批准标识的选择来定义审批或未审批订单;正常输出选择条件清单,达成需求。格式可以有不同选择;在对采购订单中单独查看时,可以看到这个发布标识的状态;..._sap查询未处理采购申请

随便推点

UAC绕过提权_uac白名单 提权-程序员宅基地

文章浏览阅读106次。UAC绕过提权_uac白名单 提权

Linux一键部署OpenVPN脚本-程序员宅基地

文章浏览阅读664次,点赞7次,收藏12次。每次架设OpenVPN Server就很痛苦,步骤太多,会出错的地方也多,基本很少一次性成功的。

头文件的相互包含问题_多个头文件相互包含-程序员宅基地

文章浏览阅读397次。 今天看了继承以及派生类,并且运行了教程中的一个实例,但是仍然有好多坑。主要如下:建立了一个基类bClass以及由基类bClass派生的一个dClass,并且建立两个头文件.h分别申明这两个类,在cpp程序中进行运行来检验。具体程序如下:#ifndef ITEM_BASE//为避免类重复定义,需要在头文件的开头和结尾加上如这个所示 #define ITEM_BASEclass bClass..._多个头文件相互包含

python -- PyQt5(designer)安装详细教程-程序员宅基地

文章浏览阅读1.3w次,点赞19次,收藏88次。PyQt5安装详细教程,安装步骤很详细

微信小程序scroll-view去除滚动条-程序员宅基地

文章浏览阅读154次。官方文档:https://developers.weixin.qq.com/miniprogram/dev/component/scroll-view.html。_scroll-view去除滚动条

POJ-3233 Matrix Power Series 矩阵A^1+A^2+A^3...求和转化-程序员宅基地

文章浏览阅读146次。S(k)=A^1+A^2...+A^k.保利求解就超时了,我们考虑一下当k为偶数的情况,A^1+A^2+A^3+A^4...+A^k,取其中前一半A^1+A^2...A^k/2,后一半提取公共矩阵A^k/2后可以发现也是前一半A^1+A^2...A^k/2。因此我们可以考虑只算其中一半,然后A^k/2用矩阵快速幂处理。对于k为奇数,只要转化为k-1+A^k即可。n为矩阵数量,m为矩阵..._a^1 a^2 ... a^k