zoukankan      html  css  js  c++  java
  • [TypeScript] Model Alternatives with Discriminated Union Types in TypeScript

    TypeScript’s discriminated union types (aka tagged union types) allow you to model a finite set of alternative object shapes in the type system. The compiler helps you introduce fewer bugs by only exposing properties that are known to be safe to access at a given location. This lesson shows you how to define a generic Result<T> type with a success case and a failure case. It also illustrates how you could use discriminated unions to model various payment methods.

    In the example, we make Result type restrict the return type, if success, it should return value, if not, return error prop.

    type Result<T> =
      | { success: true; value: T }
      | { success: false; error: string };
    
    function tryParseInt(text: string): Result<number> {
      if (/^-?d+$/.test(text)) {
        return {
            success: true,
            value: parseInt(text, 10)
        };
      }
      return {
        success: false,
        error: "Invalid number format"
      };
    }
    
    const result = tryParseInt("42");
    
    if (result.success) {
     result; // refer to success case only
     console.log(result.value)
    } else {
      result; // refer to error case only
    }
    interface Cash {
    kind: "cash";
    }
    
    interface PayPal {
    kind: "paypal";
    email: string;
    }
    
    interface CreditCard {
    kind: "creditcard";
    cardNumber: string;
    securityCode: string;
    }
    
    type PaymentMethod = Cash | PayPal | CreditCard;
    
    function stringifyPaymentMethod(method: PaymentMethod): string {
    switch (method.kind) {
        case "cash":
            return "Cash";
        case "paypal":
            return `PayPal (${method.email})`;
        case "creditcard":
            return "Credit Card";
    }
    }
    
    const myPayment = {
    kind: "paypal",
    email: "typescript@egghead.io"
    }
    
    console.log(stringifyPaymentMethod(myPayment))
  • 相关阅读:
    WebFlux系列(二) Server-Sent Events
    WebFlux系列(一)HelloWorld
    Reactor系列(十九)StepVerifier测试
    C++中vector和set使用sort方法排序
    获取线程ID
    C标准中一些预定义的宏__DATE__ __FILE__ __LINE__ __TIME__ __func__
    opencv测试代码
    nohub相关
    tensorflow相关练习
    摄像机相关
  • 原文地址:https://www.cnblogs.com/Answer1215/p/7827395.html
Copyright © 2011-2022 走看看