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))
  • 相关阅读:
    TCP三次握手和四次挥手详解
    Core Bluetooth Programming Guide
    iBeacon
    Xcode6:The file couldn’t be opened because you don’t have permission to view it
    关于IOS的蓝牙(转)
    iPad accessory communication through UART
    关于蓝牙设备与ios连接后,自动打开一个app
    Protocol
    闪屏效果
    修改avd路径
  • 原文地址:https://www.cnblogs.com/Answer1215/p/7827395.html
Copyright © 2011-2022 走看看