根据他们的wiki, TypeScript 3.0引入了未知类型:

Unknown现在是一个保留类型名,因为它现在是一个内置类型。 根据unknown的预期用途,可能需要删除 完全声明(支持新引入的未知类型),或者 将其重命名为其他内容。

未知和任何的区别是什么?什么时候用unknown代替any?


当前回答

它们在语义上有所不同。

Unknown是所有其他类型的父类型。它是类型系统中的常规类型。

Any表示“关闭类型检查”。它是一个编译器指令和一种元编程。

其他回答

任何类型:

any类型表示所有可能的JS值。每个类型都可以赋值给类型any。因此any类型是类型系统的通用超类型。TS编译器将允许对any类型的值进行任何操作。例如:

let myVar: any;

myVar[0];
myVar();
myVar.length;
new myVar();

在很多情况下,这对TS编译器来说太宽松了。也就是说,它将允许我们已经知道会导致运行时错误的操作。

未知的类型:

未知类型表示(就像任何)所有可能的JS值。每个类型都可以赋值给未知类型。因此,类型unknown是类型系统的另一个通用超类型(与any并列)。但是,TS编译器不允许对未知类型的值进行任何操作。此外,未知类型只能赋值给类型any。下面的例子将说明这一点:

let myVar: unknown;

let myVar1: unknown = myVar;   // No error
let myVar2: any = myVar;       // No error
let myVar3: boolean = myVar;   // Type 'unknown' is not assignable to type 'boolean'

// The following operations on myVar all give the error:
// Object is of type 'unknown'
myVar[0];
myVar();
myVar.length;
new myVar();

公认的答案是“未知,它是any的类型安全对应物。”

然而,正如这个例子所示,unknown是它自己的野兽,有时它的行为与其他动物非常不同:

type Foo = unknown extends string ? true : false // false
type Bar = any extends string ? true : false     // boolean - i.e. both true and false

未知的

如果编写的函数只将输入传递给另一个函数,请使用unknown。从函数的角度来看:“我不知道,我不想知道”。使用unknown并没有错。

例如:

function buy(item: unknown): Purchase {
  if (item) {
    return purchase(item);
  } else {
    throw new TypeError('item is missing');
  }
}

Any

如果需要在该值上调用属性,那么任何一个都更合适。

Linting可能不喜欢任何一个,建议你的输入更具体。这样,如果您将接口从isItem更改为isValid, typescript会告诉您更新代码。

例如:

// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
function isItem(item: any): item is Purchase {
  return !!item?.price;
}

调用属性

function isStuff(item: unknown): item is Stuff {
  return (item as Stuff).it !== undefined;
}
function isStuff(item: any): item is Stuff {
  return item.it !== undefined;
}
camelcaseKeys(item) as unknown as Item;

如果你感兴趣,请参阅用户定义守卫,我带来了它,因为这是我需要的少数情况之一。

这篇来自ultimatecourses的博客:

如果没有其他选项,请使用any类型

任何一个都很难找到好的例子。

它们在语义上有所不同。

Unknown是所有其他类型的父类型。它是类型系统中的常规类型。

Any表示“关闭类型检查”。它是一个编译器指令和一种元编程。

unknown和any的区别如下:

就像any一样,any值可以赋值给unknown;但是,与any不同的是,您不能访问类型未知的值上的任何属性,也不能调用/构造它们。此外,unknown类型的值只能赋值给unknown或any。

要回答你什么时候应该用unknown代替any的问题:

这对于想要发出“这可以是任何值”信号的api非常有用 在使用它之前,您必须执行某种类型的检查”。这就迫使 用户可以安全地自省返回值。

看看TypeScript 3.0公告中关于类型检查未知变量的例子,以及更详细的解释。