typescript typeof操作符

2023-09-18 09:21:03

ts typeof 操作符简介

在TypeScript中,typeof是一个操作符,用于获取一个值的类型。它可以与任何值一起使用,并返回一个描述该值类型的字符串。

typeof操作符在TypeScript中的用法与JavaScript中的用法非常相似。

如下,众所周知,在js中提供了typeof 操作符用来在js中获取数据的类型
在这里插入图片描述
tpyescript 中的typeof操作符和js的typeof操作符大体上一样,但ts的typeof操作符多了一些别的使用场景可以在类型上下文中引用变量或属性的类型(类型查询)

typeof 操作符js使用方式

示例如下

let num: number = 5;
console.log(typeof num); // 输出 "number"  

let str: string = "Hello";
console.log(typeof str); // 输出 "string"  

let arr: number[] = [1, 2, 3];
console.log(typeof arr); // 输出 "object"  

let obj: { name: string; age: number } = { name: "John", age: 25 };
console.log(typeof obj); // 输出 "object"  

let bool: boolean = true;
console.log(typeof bool); // 输出 "boolean"  

let undef;
console.log(typeof undef); // 输出 "undefined"  

let nullVal: null = null;
console.log(typeof nullVal); // 输出 "object"  

let func: () => void = () => { };
console.log(typeof func); // 输出 "function"

上面的示例中可以看到,typeof操作符可以正确地返回各种不同类型的字符串表示。注意,对于数组和对象,typeof操作符返回的是"object",因为在JavaScript和TypeScript中,数组和对象都是特殊的对象类型。另外,对于函数类型,typeof返回的是"function"。

在这里插入图片描述

typeof 在类型上下文中使用类型查询

使用场景,根据已有变量的值,获取该值的类型,来简化书写
示例如下

let q = { x: 1, y: 2 }

function format(q: { x: number, y: number }) { }

format(q)

我们已经拥有变量q的类型了,就没必要再次写一遍了,可以利用typeof简化书写

function format(a:typeof q){} //相当于告诉编译器,变量a的类型约束为 变量q的类型

tips :
typeof操作符在TypeScript中只能用于运行时类型检查,而不能用于编译时类型检查。因此,它不能用于确定变量的静态类型。在编译时,TypeScript编译器已经具备了强大的类型检查功能,无需使用typeof操作符来进行类型检查。

更多推荐

Linux之shell条件测试

目录作用基本用法格式:案例-f用法[]用法[[]]用法(())语法文件测试参数案例编写脚本,测试文件是否存在,不存在则创建整数测试作用操作符案例系统用户个数小于50的则输出信息逻辑操作符符号案例命令分隔符案例分析案例1---判断当前已登录的账户数,超过5个则输出信息案例2---取出/etc/passwd文件的第6行内容

Layui快速入门之第十四节 分页

目录一:基本用法API渲染属性二:自定义主题三:自定义文本四:自定义排版五:完整显示一:基本用法分页组件laypage提供了前端的分页逻辑,使得我们可以很灵活处理不同量级的数据,从而提升渲染效率<!DOCTYPEhtml><html><head><metacharset="utf-8"><title>分页</title

STM32低功耗分析

1.ARM发布最新内核2023年5月29日,Arm公司今天发布了处理器核心:Cortex-X4、Cortex-A720和Cortex-A520。这些核心都是基于Armv9.2架构,只支持64位指令集,不再兼容32位应用。Arm公司表示,这些核心在性能和效率方面都有显著的提升,同时也加强了安全性和可扩展性。Cortex-

字符串相似度算法

相似度算法JaccardSimilarityCoefficient、JaroWinkler、CosineSimilarity、Levenshtein距离编辑算法案例。Jaccard相似性系数衡量两个集合的相似程度,通过计算两个集合的交集大小除以并集大小得出。适用于处理文本、推荐系统、生物信息学等领域CosineSimi

青龙面板从0到1的实现

文章目录需要有一台云服务器Docker、SSH、青龙如何打开云服务器上的青龙面板青龙注册登录看这个青龙配置最后、从此需要有一台云服务器我这里选择的是阿里云新用户免费送的三个月服务器,服务器操作系统:CenOS(其他操作系统也可以:Ubantu、Debian)。Docker、SSH、青龙为云服务器系统安装Docker容器

支付功能、支付平台、支持渠道如何测试?

有学员提问:作为一个支付平台,接入了快钱、易宝或直连银行等多家的渠道,内在的产品流程是自己的。业内有什么比较好的测试办法,来测试各渠道及其支持的银行通道呢?作为产品,我自己办了十几张银行卡方便测试,但QA和开发不愿意这样做,怎么办呢?回答:对支付平台而言,与支付渠道相关的测试大致可以分为:测试支付渠道功能、测试支付产品

scons体验以及rtthread中的简单使用

SCons是一个用于构建软件项目的软件构建工具。它使用Python脚本作为配置文件,提供了一种简单而灵活的方式来描述软件项目的构建过程。下面是一个简单的SCons使用示例:安装SCons:首先,确保你已经安装了Python。然后,可以使用Python的包管理器pip安装SCons。在命令行中运行以下命令安装SCons:

【谢希尔 计算机网络】第2章 物理层

目录通信基础基本概念两个公式lim奈氏准则香农定理奈氏准则VS香农定理编码与调制​编辑物理层下面的传输媒体导引型传输媒体1.双绞线2.同轴电缆3.光缆非导引型传输媒体无线电微波通信卫星通信无线局域网使用的ISM频段信道复用技术频分复用、时分复用和统计时分复用波分复用码分复用CDMA工作原理CDMA的重要特点数字传输系统

01Spring的Ioc思想和依赖注入手段(DI)

传统方式创建对象的缺陷连接MySQL实现登录功能控制层UserControllerpublicclassUserController{//多态,半面向接口编程privateUserServiceuserService=newUserServiceImpl();publicvoidlogin(){Stringuserna

怒刷LeetCode的第10天(Java版)

目录第一题题目来源题目内容解决方法方法一:两次拓扑排序第二题题目来源题目内容解决方法方法一:分治法方法二:优先队列(PriorityQueue)方法三:迭代第三题题目来源题目内容解决方法方法一:迭代方法二:递归方法三:双指针方法四:栈第一题题目来源2603.收集树中金币-力扣(LeetCode)题目内容解决方法方法一:

HashMap:Java中的高性能键值对存储

一、前言HashMap是Java中最常用的数据结构之一,用于存储键值对,提供了快速的数据检索和插入操作。本文将深入探讨HashMap的内部原理、用法、常见面试问题以及源码分析。二、HashMap的内部工作原理2.1哈希表HashMap的核心是哈希表,它是一个数组,用于存储键值对。哈希表的每个位置称为"桶",每个桶可以存

热文推荐