news 2026/4/23 10:18:34

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/4/18 4:10:05

【从静态代理到动态代理,再到 AOP(一篇彻底讲透)】

从静态代理到动态代理,再到 AOP(一篇彻底讲透)从静态代理到动态代理,再到 AOP(一篇彻底讲透)一、先从一个最简单的业务开始1️⃣ 定义接口2️⃣ 实现类(真正的业务代码)二、什么是代…

作者头像 李华
网站建设 2026/4/23 6:52:41

近视防控大揭秘:防什么?控什么?为啥这么重要?

在青少年视力健康问题愈发受关注的当下,近视防控早已不是一句口号,而是贯穿家庭、校园与日常用眼场景的重要课题。很多人对近视防控的认知停留在“少看电子产品”,却不清楚防控的核心目标、关键原理,以及日常场景中存在的防控痛点…

作者头像 李华
网站建设 2026/4/4 14:51:55

Java人工智能框架:JBoltAI三大核心优势解析

在 Java 企业级 AI 应用开发领域,框架的适配性、扩展性和可管理性直接影响项目推进效率。JBoltAI 作为专为 Java 生态设计的 AI 应用开发框架,在标准化接口、可插拔架构、可治理框架三大核心维度形成独特优势,为 Java 技术团队提供了贴合实际…

作者头像 李华
网站建设 2026/4/23 9:48:22

使用 GLM-4 和 MCP 实现智能文章发布

使用 GLM-4 和 MCP 实现智能文章发布 本文介绍如何结合 GLM-4 大模型和 MCP (Model Context Protocol) 实现一个智能文章发布系统。 技术栈 GLM-4: 智谱AI的大语言模型MCP: 模型上下文协议Spring AI: Spring AI 框架Spring Boot: 应用框架 功能特性 智能理解用户意图自动提取文…

作者头像 李华
网站建设 2026/4/23 9:48:26

453345345

453475354

作者头像 李华