typescript 类型映射 (ReadOnly、Partial)

应用特点

有时候需要一个类型,是依赖于上一个类型但是,对属性的要求去不同

interface Person{
    name: string;
    agent: number;
}
type Person2 = Readonly;
type Person3 = Partial;
class Test {
    run() {
        let person: Person = {
            name: 'dd',
            agent: 1
        };
        person.name = 'cc';
        let person2: Person2 = {
            name: 'read',
            agent: 1
        };
        // person2.agent = 3; 报错
        let person3: Person3 = {
            name: 'person 3' // 属性不完整也不会报错
        }
    }
}

ReadOnly、Partial源码

type Readonly = {
    readonly [P in keyof T]: T[P];
}
type Partial = {
    [P in keyof T]?: T[P];
}

ddd

其实这些主要在定义是灵活应用 in, keyof即可实现


type Pick = {
    [P in K]: T[P];
}
type Record = {
    [P in K]: T;
}

你可能感兴趣的:(typescript,typescript,类型映射)