【问题标题】:JSON parse in typescript validating props打字稿验证道具中的 JSON 解析
【发布时间】:2018-09-07 00:31:15
【问题描述】:
class Book {
    title: string;
    datePublished: Date;

    static unserialize(str) {
        let ret = JSON.parse(str, (key, value) => {
            switch (key) {

                case 'datePublished': return new Date(value);

                default:return value;
            }
        }) as Book;

        return ret;
    }
}

取消序列化对象时,您可以像示例中一样使用 JSON.parse 中的 revive 函数。但是您正在通过常量字符串中的名称访问对象的属性,从而失去了打字稿的“控制”(例如,重构更改道具的名称不会反映在 switch 案例中)。

有没有更好的方法来使用打字稿的可能性?

【问题讨论】:

标签: typescript serialization


【解决方案1】:

不确定这是否是最佳解决方案,但我遇到了一种至少可以标记错误的方法。重构不会更改文字名称,但会在更改后标记为错误。

诀窍是将键的类型设置为 as keyof Book

class Book {
    title: string;
    datePublished: Date;

    static unserialize(str) {
        let ret = JSON.parse(str, (key: keyof Book, value) => {  // "keyof Book" does the trick

            switch (key) {

                case 'datePublished': return new Date(value);
                case 'xitle' : return value;        // [ts] Type '"xitle"' is not comparable to type '"title" | "datePublished"
                default:return value;
            }
        }) as Book;

        return ret;
    }
}

【讨论】:

  • 有没有更好的方法,因为我有很多属性?
猜你喜欢
  • 2023-01-24
  • 2019-01-13
  • 2020-05-23
  • 2017-01-22
  • 2020-12-26
  • 1970-01-01
  • 2017-04-12
  • 2017-01-28
  • 1970-01-01
相关资源
最近更新 更多