TypeScript中的keyof、typeof、in

2024-02-21 21:36
文章标签 typescript keyof typeof

本文主要是介绍TypeScript中的keyof、typeof、in,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概览

TypeScript中的keyof、typeof、in在我们日常工作中经常用到,但也容易遗忘,现详细梳理其用法及使用场景

一. 抛出问题

const getFormatData = (initData) => {  const data = [];// 部分字段取值需保留小数点后两位const formatKeys = ['priceUntax','packageCoast','transfeCoast','manageCoast','profitReal','totalCoast'];  initData.forEach(item => {  const tempDataItem = {} ;  // 遍历 tableMapKeyValue 对象的每个键值对  for (const [key, value] of Object.entries (tableMapKeyValue)) {  if(!item[value]) {tempDataItem[key] = ''} else {tempDataItem[key] = formatKeys.includes(key)? Number(item[value]).toFixed(2): item[value]}}  data.push(tempDataItem);  });  return data;  };

在vue项目中,这段代码有编译报错,代码可能看得不清楚,上图片
在这里插入图片描述

修复代码1

const getFormatData = <T extends { [K in keyof typeof tableMapKeyValue]: any }>(initData:any[]): T[] => {  const data: T[] = [];// 部分字段取值需保留小数点后两位const formatKeys = ['priceUntax','packageCoast','transfeCoast','manageCoast','profitReal','totalCoast'];  initData.forEach(item => {  const tempDataItem: T = {} as T;  // 遍历 tableMapKeyValue 对象的每个键值对  for (const [key, value] of Object.entries (tableMapKeyValue)) {  if(!item[value]) {tempDataItem[key] = ''} else {tempDataItem[key] = formatKeys.includes(key)? Number(item[value]).toFixed(2): item[value]}}  // 将 tempDataItem 添加到 data 数组中  data.push(tempDataItem);  });  return data;  };

修复代码2

const getFormatData = (initData:any[]) => {  const data:ItableMapKeyValue[] = [];// 部分字段取值需保留小数点后两位const formatKeys = ['priceUntax','packageCoast','transfeCoast','manageCoast','profitReal','totalCoast'];  initData.forEach(item => {  const tempDataItem: ItableMapKeyValue = {} as ItableMapKeyValue;  // 遍历 tableMapKeyValue 对象的每个键值对  for (const [key, value] of Object.entries (tableMapKeyValue)) {  if(!item[value]) {tempDataItem[key] = ''} else {tempDataItem[key] = formatKeys.includes(key)? Number(item[value]).toFixed(2): item[value]}}  data.push(tempDataItem);  });  return data;  };

相关调用代码如下:

const importExcel = (params:any[]) => {const formatData = getFormatData(params);data.value.details = formatData;}

相关引用代码

export interface ItableMapKeyValue {goodsNo: string,descr: string,number: string,unit: string,priceUntax: string,packageCoast: string,transfeCoast: string,manageCoast: string,profitReal: string,totalCoast: string,remarks: string
}export const tableMapKeyValue:ItableMapKeyValue = {goodsNo:'物料编号',descr:'描述',number:'数量',unit:'单位',priceUntax:'单价(未含税)',packageCoast:'包装费用(元)',transfeCoast:'运输费用(元)',manageCoast:'管理服务费用(元)',profitReal:'毛利率(%)',totalCoast:'总价(未含税)(元)',remarks:'备注'
}

二. keyof

keyof 可以获取一个类型所有键值,返回一个联合类型

type Person = {name:string;age:number;
}type PersonKey = keyof Person; // 'name'|'age'

三. typeof

typeof 可以获取一个对象/实例的类型

const person = {name:'xiaobai',age:3
}const p1:typeof person = {name:'xiaohong',age:2
}// typeof person 输出 {name:string, age:number}

三. in 操作符

遍历枚举的类型, 可以和keyof配合使用,作类型转换等

type Person = {name:string;age:number;
}type PersonToString<T> = {[k in keyof T]:string
}const p1:PersonToString<Person> = {name:'xiaobai',age:"10"
}
// {name:string, age:string}

四. 使用示例

1. 实现 Partial

Partial是一个ts内置工具类型,用于将传入的类型所有属性设置为可选的

type User = {id:number,phone:number,pwd:string,name:string
}const u1:Partial<User> = {id:1,name:'小白'
}
// 自己实现
type MyPartial<T> = {[k in keyof T]?: T[k]
}const u2:MyPartial<User> = {id:2,name:'小红'
}

2. 实现 Readonly
Readonly工具类型可以将传入的类型中所有属性转化为只读

type User = {id:number,name:string
}
// 自己实现
type MyReadonly<T> = {readonly [k in keyof T]: T[k]
}const u1:MyReadonly<User> = {id:3,name:'小黄'
}u1.name = '小黑' 
//Cannot assign to 'name' because it is a read-only property.

3. 实现 Record
Record<Keys, Type>工具类型可以将某个类型的属性映射到另一个类型上,其构造的类型属性名的类型为K,属性值的类型为T

type Page = 'home' | 'about' | 'contact';
interface PageInfo {title: string;
}const x1: Record<Page, PageInfo> = {about: { title: 'about' },contact: { title: 'contact' },home: { title: 'home' },
};// 自己实现
type MyRecord<Keys extends keyof any, Type> =  {[k in Keys]: Type
}
const x2: MyRecord<Page, PageInfo> = {about: { title: 'about' },contact: { title: 'contact' },home: { title: 'home' },
};

这篇关于TypeScript中的keyof、typeof、in的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

创建 typescript 项目.md

有时候需要创建一个最简单的 typescript 项目来验证一些东西,这里记录一下如何创建一个最简单的 typescript 项目。 创建并初始化项目 $ mkdir my-typescript-project$ cd my-typescript-project$ npm init -y$ npm install typescript ts-node @types/node --save

TypeScript数据结构与算法系列(一) —— 链表

TypeScript目录 链表常用操作1.初始化链表2. 插入节点3. 删除节点4. 访问节点5. 查找节点 图源:你好算法 内存空间是所有程序的公共资源,在一个复杂的系统运行环境下,空闲的内存空间可能散落在内存各处。我们知道,存储数组的内存空间必须是连续的,而当数组非常大时,内存可能无法提供如此大的连续空间。此时链表的灵活性优势就体现出来了。 链表(linked list)

VueSax-解决Vue3报错问题,并支持typescript

以下为坑点 根据官方提示,本人在vue3+typescript的项目中添加了vuesax的组件依赖 根据正常的导入依赖思路编写代码,发现typescript一直报 查询vuesax的目录文件发现存在ts文件,于是乎觉得是自己的问题,就查阅gpt与网上资料,查了一晚上加入各种方法,都没有解决,于是乎选择javascript进行测试,发现还是不行! js里虽然不报错,但是在页面

Vue3 + TypeScript 实现防抖(Debounce)和节流(Throttle)

在Vue3项目中结合TypeScript使用防抖(Debounce)和节流(Throttle)技术,可以有效提升应用的性能和用户体验,尤其是在处理频繁触发的事件(如滚动、窗口大小调整、输入框内容变化等)时。下面将详细介绍这两种技术的原理、使用方法以及适用场景。 一、防抖(Debounce) 原理: 防抖技术通过延迟函数的执行来减少函数的调用频率。在事件被触发n秒后再执行回调,如果在这

Typescript实现react-redux的useSelector和useDispatch的状态定义

背景:react中使用typescript,在引入redux之后很多状态定义有问题,记录下来(文章记录学习react-redux过程中的踩坑)。 1.useSelector时,state语法报错,类型为unknown,如下图 我的store状态设置的很简单,两个模块导出,只在state中定义了一个基础类型 在组件中使用useSelector取state中的值,然后报state类型未知 我

TypeScript中的函数与类

TypeScript中的类 传统的JavaScript程序使用函数和基于原型的继承来创建可重用的组件,但对于熟悉使用面向对象方式的程序员来讲就有些棘手,因为他们用的是基于类的继承并且对象是由类构建出来的。 从ECMAScript 2015,也就是ECMAScript 6开始,JavaScript程序员将能够使用基于类的面向对象的方式。 使用TypeScript,我们允许开发者现在就使用这些特性,

Typescript 常用变量类型声明

函数声明变量 // 基础类型(number、boolean、string)const int = (arg1: number) {// ...}// 数组类型const arr1 = (arg1: number[]) {// ...}// 另一种写法,使用泛型const arr2 = (arg1: Array<number>) {// ...}// 任意类型(any)// a

VUE3+FLASK+TYPESCRIPT(实习接触,学习并自主实现)

开头         不同于笔者在学校自学简单的html+js+css的模式,加入了前端框架VUE3真的是一个非常方便的工具,而且本人主攻于c++方向,像ts这种更严格的语法标准反而更加比原生js更能让我接受,由于这三个都是本人没接触的库框架和语言,所以笔者采取的是先学习在边做项目边巩固的方法。 VUE3初始化         下面提供一个简单的VUE3+FLASK案例,旨在入门 打通Vu

Typescript 使用 Jest 进行单元测试

参考文章:快速开始·Jest 安装所需依赖:npm install --save-dev ts-node jest @types/jest ts-jest Jest 转换 TypeScript 代码需要ts-node添加并配置 Jest 配置文件:jest.config.ts // jest.config.tsmodule.exports = {// TypeScript 代码预处理pres

TypeScript与vue

一、为组件的props标注类型         - 在没有使用TS之前,是这样接受props:                          - 在TS环境中,是这样接受props:                          - 对于props的可选项如何限制呢?                 1、类型限制                         类型限制在接收