欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

知识点文件说明 II

最编程 2024-03-16 18:03:07
...
3月16日,北京源创会 —— “数据库,2024 开炫”

类型操作符

  • keyof T索引类型查询操作符。 对于任何类型 T, keyof T的结果为 T上已知的公共属性名的联合

  • T[K], 索引访问操作符。 只要确保类型变量 K extends keyof T
function pluck<T, K extends keyof T>(o: T, names: K[]): T[K][] {
  return names.map(n => o[n]);
}

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

let personProps: keyof Person; // 'name' | 'age'

// keyof Person是完全可以与 'name' | 'age'互相替换的
  • as操作符 用于类型断言  意为开发人员明确知道该参数的类型,不需要ts去推断是否正确

let someValue:any = document.querySelector('div')
let el: HTMLElement = someValue as HTMLElement
// 等价于尖括号形式
let el: HTMLElement = <HTMLElement>someValue

// 另外有非空断言 someValue!: XXX; 意为 someValue 不进行 null 或 undefined 校验

预定义的有条件类型

TypeScript 2.8在lib.d.ts里增加了一些预定义的有条件类型:

  • Exclude<T, U> -- 从T中剔除可以赋值给U的类型。
  • Extract<T, U> -- 提取T中可以赋值给U的类型。
  • NonNullable<T> -- 从T中剔除nullundefined
  • ReturnType<T> -- 获取函数返回值类型。
  • InstanceType<T> -- 获取构造函数类型的实例类型。
type T00 = Exclude<"a" | "b" | "c" | "d", "a" | "c" | "f">;  // "b" | "d"
type T01 = Extract<"a" | "b" | "c" | "d", "a" | "c" | "f">;  // "a" | "c"

type T02 = Exclude<string | number | (() => void), Function>;  // string | number
type T03 = Extract<string | number | (() => void), Function>;  // () => void

type T04 = NonNullable<string | number | undefined>;  // string | number
type T05 = NonNullable<(() => string) | string[] | null | undefined>;  // (() => string) | string[]

function f1(s: string) {
    return { a: 1, b: s };
}

class C {
    x = 0;
    y = 0;
}

type T10 = ReturnType<() => string>;  // string
type T11 = ReturnType<(s: string) => void>;  // void
type T12 = ReturnType<(<T>() => T)>;  // {}
type T13 = ReturnType<(<T extends U, U extends number[]>() => T)>;  // number[]
type T14 = ReturnType<typeof f1>;  // { a: number, b: string }
type T15 = ReturnType<any>;  // any
type T16 = ReturnType<never>;  // any
type T17 = ReturnType<string>;  // Error
type T18 = ReturnType<Function>;  // Error

type T20 = InstanceType<typeof C>;  // C
type T21 = InstanceType<any>;  // any
type T22 = InstanceType<never>;  // any
type T23 = InstanceType<string>;  // Error
type T24 = InstanceType<Function>;  // Error

typeof关键字,当在表示类型的地方使用时,会得出一个类型值 

    推荐阅读