【TypeScript】TS类型声明(五)

简介: JS 中是没有空值(Void)的概念,但是在 TS 中,我们可以用 void 表示没有任何返回值的函数。在TypeScript 中的 void 是 undefined 的子类型

void(空类型)

JS 中是没有空值(Void)的概念,但是在 TS 中,我们可以用 void 表示没有任何返回值的函数。在TypeScript 中的 void 是 undefined 的子类型。JavaScript 中的函数总是会返回给我们一些数据。要么是一个值,要么是 undefined。没有返回值的函数总是给我们返回 undefined,并且 void 在 JavaScript 中总是返回 undefined,因此 TypeScript 中的 void 是告诉开发人员此函数是返回 undefined 的合适类型。
声明对象类型为void

  • 返回为空值
function func(): void { }

声明一个变量为void

  • 只能将它赋值为 undefined 和 null,因此在定义函数的返回值为void时,也可return undefined/null
let voidValue1: void = undefined;
let voidValue2: void = null;

never(不存在的值类型)

never类型表示永不存在的值的类型。具有以下特点:

  • never类型是所有类型的子类型,即never类型可以赋值给任何类型。
  • 其他任何类型均不是never类型的子类型,即其他类型均不可赋值给never类型,除了never本身。即使any类型也不可以赋值给never类型。
  • 返回类型为never的函数中,其终点必须是不可执行的,例如函数过程中抛出了错误或者存在死循环。
  • 变量也可以声明为never类型,但其不能被赋值

设置变量类型为never,表示永远不能执行完或者永远Error,具体示例如下:

  • 函数中出现了死循环,永远不能执行完,因此其函数类型为:() => never
function infiniteLoop(): never {
    while (true) { }
    return 'over'
}
  • 函数中出现报错,不会执行到return over,因此其函数类型为:() => never
function errFunc(): never {
    throw new Error()
    return 'over'
}

void与never的区别

void类型可以用于声明函数的返回值类型来表示函数没有任何返回值,但是void表示的意思就变得很模糊了。使用void的话,函数是可以返回undefined的,而采用never则不允许函数返回undefined。实际项目开发中,我们不能完全依赖于TypeScript设置的类型推断系统来帮助我们生成正确的类型信息。当需要明确表明函数无返回值时,需要将其返回值类型指定为never。

目录
相关文章
|
1月前
|
JavaScript 前端开发 安全
深入理解TypeScript:增强JavaScript的类型安全性
【10月更文挑战第8天】深入理解TypeScript:增强JavaScript的类型安全性
45 0
|
3天前
|
JavaScript 安全 前端开发
TypeScript类型声明:基础与进阶
通过本文的介绍,我们详细探讨了TypeScript的基础与进阶类型声明。从基本数据类型到复杂的泛型和高级类型,TypeScript提供了丰富的工具来确保代码的类型安全和可维护性。掌握这些类型声明能够帮助开发者编写更加健壮和高效的代码,提高开发效率和代码质量。希望本文能为您在使用TypeScript时提供实用的参考和指导。
10 2
|
16天前
|
JavaScript 开发者
在 Babel 插件中使用 TypeScript 类型
【10月更文挑战第23天】可以在 Babel 插件中更有效地使用 TypeScript 类型,提高插件的开发效率和质量,减少潜在的类型错误。同时,也有助于提升代码的可理解性和可维护性,使插件的功能更易于扩展和升级。
|
27天前
|
JavaScript 前端开发
TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第11天】TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
30天前
|
JavaScript 前端开发 安全
TypeScript【基础类型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第9天】TypeScript【基础类型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
1月前
|
JavaScript 前端开发 开发者
深入理解TypeScript:类型系统与最佳实践
【10月更文挑战第8天】深入理解TypeScript:类型系统与最佳实践
|
1月前
|
移动开发 JavaScript 前端开发
TypeScript:数组类型&函数使用&内置对象
本文介绍了 TypeScript 中的数组类型、对象数组、二维数组、函数、函数重载、内置对象等概念,并通过代码示例详细展示了它们的使用方法。还提供了一个使用 HTML5 Canvas 实现的下雨效果的小案例。
|
15天前
|
JavaScript 前端开发 安全
TypeScript进阶:类型系统与高级类型的应用
【10月更文挑战第25天】TypeScript作为JavaScript的超集,其类型系统是其核心特性之一。本文通过代码示例介绍了TypeScript的基本数据类型、联合类型、交叉类型、泛型和条件类型等高级类型的应用。这些特性不仅提高了代码的可读性和可维护性,还帮助开发者构建更健壮的应用程序。
22 0
|
1月前
|
JavaScript 索引
TypeScript(TS)安装指南与基础教程学习全攻略(二)
TypeScript(TS)安装指南与基础教程学习全攻略(二)
51 0
|
1月前
|
JavaScript 前端开发 安全
TypeScript(TS)安装指南与基础教程学习全攻略(一)
TypeScript(TS)安装指南与基础教程学习全攻略(一)
28 0