zoukankan      html  css  js  c++  java
  • [Typescript] Statically Type Unknown Values with TypeScript's unknown Type

    In this lesson, we'll go over TypeScript's unknown type. The unknown type is the type-safe counterpart of the any type. Both unknown and any are so-called top types (also known as universal supertypes) of the type system. This means that every type in TypeScript is assignable to both unknown and any.

    The main difference between the two types is that unknown is much less permissive than any: We have to do some form of checking before performing most operations on values of type unknown, whereas we don't have to do any checks before performing operations on values of type any.

    Another difference is that any is assignable to every type, whereas unknown is only assignable to any and unknown itself. To assign unknown to any other types, we have to narrow it to a more specific type first.

    • Replace `any` in most cases
    • Suitable for library author
    • `unknow` + `function overload` + `type checking`
    function range(from: number, to: number): number[];
    function range(from: unknown, to: unknown): number[] {
      if (typeof from !== "number" || typeof to !== "number") {
        throw Error("range() expects exactly 2 numbers");
      }
    
      const values: number[] = [];
      for (let i = from; i < to; i++) {
        values.push(i);
      }
      return values;
    }
    
    console.log(range(0, 5));

    Function overload: help user to see the correct type `number` instead od `unknown`.

    Why using `unknown` instead of `number` directly?

    function range(from: number, to: number): number[] {
      const values: number[] = [];
      for (let i = from; i < to; i++) {
        values.push(i);
      }
      return values;
    }

    It is good enough for the project you are working on with Typescript.

    But if it is a library. Users might use Javascript without typing system. Without `if type checking`, might casue issue.

  • 相关阅读:
    20000+关注,开源两本硬核的原创电子书!
    Tail Latency学习
    Zabbix5.0 监控redis
    JAVA多线程(九) ForkJoin框架
    JAVA多线程(八) Condition源码分析
    程序员英语学习(二) 标点符号对应的英语单词汇总
    linux shell快速入门
    Ubuntu常用指令和快捷键汇总
    Win10常用快捷键汇总
    算法路漫漫(三) 荷兰国旗
  • 原文地址:https://www.cnblogs.com/Answer1215/p/14722241.html
Copyright © 2011-2022 走看看