typescript中循环对象(for...in)的类型问题 keyof

2024-03-28 20:28

本文主要是介绍typescript中循环对象(for...in)的类型问题 keyof,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1)、 在js里,对象的键是变量没有问题。直接使用: 对象[键名]

2)、在ts里,就需要对键名做专门的类型定义

一、定义对象时,明确写出键和值的取值类型。

let obj: { [key: string]: any }

代码示例:

1、给对象定义类型时,明确写出对象的键的类型和可接受的值的类型。如:
let obj: { [key: string]: any }
表示obj变量是对象类型,键是字符串类型,值是any类型。obj = { name: "张三疯", age: 12 };for (const key in obj) {console.log(`${key}: ${obj[key]}`);
}再如:
let obj: { [key: string]: (number | string) }
表示obj变量是对象类型,键是字符串类型,值是number | string 类型。
obj = { name: "张三疯", age: 12 };for (const key in obj) {console.log(`${key}: ${obj[key]}`);
}

注意:key取值只能是string,number,symbol,或者 template literal type(模板文字类型)

二、如果定义对象时,对象的属性名和类型都对应的明确了

(如:用interface或者type定义了对象类型)。

就可以使用 keyof 的方式限制键的取值可能性。如下示例。要注意看注释。

interface IBanner {img: string;alt: string;link: string;
}let obj: IBanner;
obj = {"img":"hello","alt":"这是一张图片","link":"https://blog.csdn.net/jiang7701037"
};// 下面这句话限定了key的取值只能是字符串:"img","alt","link",
let key:keyof typeof obj;//或者:let key:keyof IBanner;
for(key in obj){console.log(`${key}: ${obj[key]}`);//???如果企图在这里面给 obj[key]赋值的话,是做不到的。因为,ts对obj[key]推论出的类型是never。
}// key ="img";
key ="hello";//不能这样赋值,因为 key的取值只能是字符串:"img"、"alt"、"link" 三者之一。

三、再看一个稍微复杂一点的例子。也是用了keyof

interface ITypeIndex {extralarge: "extralarge";major: "major";ordinary: "ordinary";
}// 定义对象类型
interface IState{text:string,count:number;type:keyof ITypeIndex; //此处如果写成字符串是不行的, keyof ITypeIndex就是类型的定义。
}// 定义对象数组
const states:IState[] = [{text:"特大",count:2,type:"extralarge"},{text:"重大",count:10,type:"major"},{text:"一般",count:20,type:"ordinary"}
]interface IObj {extralarge: number;major: number;ordinary: number;
}const obj:IObj = {extralarge: 1,major: 2,ordinary: 3,
}states.forEach(item=>{console.log(obj[item.type]);
})

这篇关于typescript中循环对象(for...in)的类型问题 keyof的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/856619

相关文章

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,