zoukankan      html  css  js  c++  java
  • [TypeScript] Use TypeScript’s never Type for Exhaustiveness Checking

    TypeScript 2.0 introduced a new primitive type called never, the type of values that never occur. It helps model the completion behavior of functions more accurately and can also be used for exhaustiveness checking.

    never type means that 'That part of code cannot be reached'.

    In somecases, never type can be useful as well.

    const enum ShirtSize {
      XS,
      S,
      M,
      L,
      XL
    }
    
    function assertNever(value: never): never {
      // throw Error(`Unexpected value '${value}'`)
      // Adjusted for plunker output
      console.log(Error(`Unexpected value '${value}'`));
    }
    
    function prettyPrint(size: ShirtSize) {
      switch (size) {
          case ShirtSize.S: console.log("small");
          case ShirtSize.M: return "medium";
          case ShirtSize.L: return "large";
          case ShirtSize.XL: return "extra large";
          // [ts] Argument of type 'ShirtSize.XS' is
          // not assignable to parameter of type 'never'.
          default: return assertNever(size);
      }
    }
    
    prettyPrint(ShirtSize.S)
    prettyPrint(ShirtSize.XXL)

    In the example, we want to make sure that every time in the enum ShirtSzie has been handled by the 'prettyPrint' function.

    But sometime, we might miss one case. That's where 'assertNever' function can help to make sure, we have gone though all the cases.

  • 相关阅读:
    tyvj1034 尼克的任务
    一维数状数组区间修改,查询
    ACM-T3分块
    测试2T3
    IOS下自定义click事件使用alert的bug
    小知识点
    CSS3动画基本知识
    CSS3秘笈:第十二章&第十三章
    CSS3秘笈:第十一章
    CSS3秘笈:第十章
  • 原文地址:https://www.cnblogs.com/Answer1215/p/7811540.html
Copyright © 2011-2022 走看看