Typescript: назначить атрибут readonly в функции внутри конструктора - PullRequest
0 голосов
/ 04 января 2019

У меня есть класс с атрибутом только для чтения, который я определяю внутри function внутри constructor, компилятор выдает ошибку, которую я не знаю, как решить:

    class TEST {
        public readonly desc: string;

        constructor() {
            const compute = () => {
                this.desc = "description"
            };
        }
    }

Компилятор говорит: "Cannot assign to "desc" because it is a readonly property" но я подумал, что назначение свойства внутри конструктора позволит избежать ошибок такого рода. Возможно ли это или я должен изменить реализацию?

1 Ответ

0 голосов
/ 04 января 2019

Вам понадобится утверждение типа, чтобы обойти его, самый безопасный способ использовать сопоставленный тип, который удаляет readonly из типа:

type Mutable<T> = {
    -readonly [P in keyof T]: T[P];
};
class TEST {
    public readonly desc!: string;

    constructor() {
        const compute = () => {
            (this as Mutable<TEST>).desc = "description"
        };
    }
}

readonly - довольно слабый модификатор, поэтому, если вы не возражаете передать this в качестве параметра, вы можете избежать утверждения:

class TEST {
    public readonly desc!: string;

    constructor() {
        const compute = (target: Mutable<TEST>) => {
            target.desc = "description"
        };
        compute(this)// works fine and not just because we are in teh constructor
    }
}
...