news 2026/6/15 14:13:33

Typescript - void 类型(详细入门教程)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Typescript - void 类型(详细入门教程)

前言

由于 any / unknown 类型几乎 “相似” ,所以可以直接一起学习。

在 Typescript 中,当我们不确定一个类型是什么类型的,可以选择给其声明为 any 或者 unkown。

本文会介绍这两种类型的介绍及其示例用法,最后谈一下二者的区别。

any 类型

在 TypeScript 中,任何类型都可以被归为 any 类型,因为它可以被赋予任何值。

这让 any 类型成为了类型系统的顶级类型(也被称作全局超级类型),如下代码所示:

letnotSure:any=666;notSure="王佳斌";notSure=false;

TypeScript 允许我们对 any 类型的值执行任何操作,而无需事先执行任何形式的检查,如下代码所示:

letvalue:any;value.foo.bar;// OKvalue.trim();// OKvalue();// OKnewvalue();// OKvalue[0][1];// OK

在许多场景下,这太宽松了。使用 any 类型,可以很容易地编写类型正确但在运行时有问题的代码。

如果您使用 any 类型,就无法使用 TypeScript 提供的大量的保护机制。

unknown 类型

为了解决 any 带来的问题,TypeScript 3.0 引入了 unknown 类型。

就像所有类型都可以赋值给 any,所有类型也都可以赋值给 unknown。

这使得 unknown 成为 TypeScript 类型系统的另一种顶级类型(另一种是前面的 any),如下代码所示:

letvalue:unknown;value=true;// OKvalue=42;// OKvalue="Hello World";// OKvalue=[];// OKvalue={};// OKvalue=Math.random;// OKvalue=null;// OKvalue=undefined;// OKvalue=newTypeError();// OKvalue=Symbol("type");// OK

对 value 变量的所有赋值都被认为是类型正确的。

但是,当我们尝试将类型为 unknown 的值赋值给其他类型的变量时会发生什么?

letvalue:unknown;letvalue1:unknown=value;// OKletvalue2:any=value;// OKletvalue3:boolean=value;// Errorletvalue4:number=value;// Errorletvalue5:string=value;// Errorletvalue6:object=value;// Errorletvalue7:any[]=value;// Errorletvalue8:Function=value;// Error

unknown 类型只能被赋值给 any 类型和 unknown 类型本身。直观地说,这是有道理的:只有能够保存任意类型值的容器才能保存 unknown 类型的值。毕竟我们不知道变量 value 中存储了什么类型的值。

现在让我们看看当我们尝试对类型为 unknown 的值执行操作时会发生什么。以下是我们在之前 any 看过的相同操作:

letvalue:unknown;value.foo.bar;// Errorvalue.trim();// Errorvalue();// Errornewvalue();// Errorvalue[0][1];// Error

将 value 变量类型设置为 unknown 后,这些操作都不再被认为是类型正确的。通过将 any 类型改变为 unknown 类型,我们已将允许所有更改的默认设置,更改为禁止任何更改。

二者区别

其实很明显,可以用以下表格表示。

相同点不同点
都可以赋予任意类型的值unknown 类型的值不能直接赋值给其他变量
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:30:48

探索 SIMULINK 下 BLDC 的速度控制:霍尔六步换相与 FOC 控制之旅

SIMULINKBLDC速度控制(霍尔六步换相/FOC控制) 1.霍尔信号,反电动势,电角度之间的关系,可以直接观测 2.附带了一些常见的解释说明 3.采用自建的bldc模型 4.带有整理的一份ppt(这个很重要) 5.一些…

作者头像 李华
网站建设 2026/6/15 12:18:15

【Spring Boot注解】

Spring Boot注解 Spring Boot 注解是如何工作的?(理解 AOP 的前置知识)一、Spring 到底在干什么?一句话版本二、为什么 Service 的类不用 new?1️⃣ 一个最简单的 Spring Boot 程序 三、Service / Component 是干嘛的&…

作者头像 李华
网站建设 2026/6/15 11:20:10

探索整车 Simulink 七自由度模型:从理论到实践

完整的整车simulink七自由度模型在汽车动力学研究领域,整车的 Simulink 七自由度模型宛如一座基石,为深入理解车辆运动特性和性能分析搭建了坚实的框架。今天咱们就来唠唠这个完整的整车 Simulink 七自由度模型。 七自由度模型的理论基础 从理论层面看&a…

作者头像 李华
网站建设 2026/6/15 12:19:13

2026年最值得收藏的10个测试开源项目(附GitHub链接)

随着AI与测试技术的深度融合,2026年软件测试领域迎来开源工具的爆发式创新。这些工具不仅提升了测试效率和覆盖率,还推动了测试工程师从传统脚本执行向“AI训练师”和“质量策略设计师”的角色转型。本文精选10个最具价值的开源项目,每个项目…

作者头像 李华
网站建设 2026/6/15 12:18:16

随着大模型技术的发展——RAG技术有可能会被淘汰吗?

“ RAG技术未来并不会被淘汰,只不过会随着技术的迭代而不断升级。” 关于RAG技术有很多不同的观点,有人认为RAG技术是大模型的阶段性解决方案,最终会被淘汰;但也有人认为RAG技术仍不能被替代,其作用依然无可代替&#…

作者头像 李华