手记

【十月打卡】第60天 TypeScript(16)

类型描述文件

  • 类型描述文件格式为*.d.ts
  • 全局或者模块需要declare来声明

全局

如下以jquery来举例

// index.html
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js"></script>
<script src="./src/index.ts"></script>

// index.ts
$(function () {
  $('body').html('<div>Hello world</div>');
});

针对上面用法的类型描述文件:jquery.d.ts

interface JqueryInstance {
  html: (html: string) => JqueryInstance;
}

// 方式一:函数重载
declare function $(readyFn: () => void): void;
declare function $(selector: string): JqueryInstance;

// 方式二:使用interface,实现函数的重载
interface Jquery {
  (readyFn: () => void): void;
  (selector: string): JqueryInstance;
}
declare var $: Jquery;

如果jquery增加了对象以及类怎么处理?

$(function () {
  $('body').html('<div>Hello world</div>');
  new $.fn.init();
});
interface JqueryInstance {
  html: (html: string) => JqueryInstance;
}

declare function $(readyFn: () => void): void;
declare function $(selector: string): JqueryInstance;

// 命名空间实现对象以及类进行类型定义
declare namespace $ {
  namespace fn {
    class init {}
  }
}

模块

如果jquery是以模块来引入,类型描述文件该怎么处理呢

import $ from 'jquery';
$(function () {
  $('body').html('<div>Hello world</div>');
  new $.fn.init();
});
  • 声明模块加上module
  • 通过export导出
declare module 'jquery' {
  interface JqueryInstance {
    html: (html: string) => JqueryInstance;
  }

  // 重载
  function $(readyFn: () => void): void;
  function $(selector: string): JqueryInstance;
  namespace $ {
    namespace fn {
      class init {}
    }
  }

  // 导出
  export  = $;
}

泛型结合keyof

先看下面实例
TS报错:return this.info[key]
原因:因为getInfo传入的参数无法保证是name、age或者gender中的一个

interface Person {
  name: string;
  age: number;
  gender: string;
}

class Teacher {
  constructor(private info: Person) {}
  getInfo(key: string) {
    return this.info[key];  // 报错
  }
}

const teacher = new Teacher({
  name: 'tz',
  age: 30,
  gender: 'male',
});

teacher.getInfo('name');

通过keyof可以来解决, keyof遍历Person的属性

interface Person {
  name: string;
  age: number;
  gender: string;
}

class Teacher {
  constructor(private info: Person) {}
  getInfo<T extends keyof Person>(key: T): Person[T] {
    return this.info[key];
  }
}

const teacher = new Teacher({
  name: 'tz',
  age: 30,
  gender: 'male',
});

teacher.getInfo('name');
2人推荐
随时随地看视频
慕课网APP