位置: IT常识 - 正文

TS中快速定义一个对象数组以及处理async await的异常(ts中如何定义一个数组)

编辑:rootadmin
TS中快速定义一个对象数组以及处理async await的异常

推荐整理分享TS中快速定义一个对象数组以及处理async await的异常(ts中如何定义一个数组),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:ts中的keyof,ts中的typeof,ts自定义类型,ts中如何定义一个数组,ts怎么设置快捷键,ts自定义类型,ts中如何定义一个数组,ts中declare,内容如对您有帮助,希望把文章链接给更多的朋友!

定义一个对象数组(即数组成员为对象,对象的属性为我们所约束)

方法一:接口字面量形式

export type Resource= {_id: string,personID: { _id: string age: string identifier: string name: string nation: string grade: string schemeNum: string organ: string sex: string}gaintestPoint:stringlooktestPoint:string[]viocetsetPoint:stringgameReview:stringAddvice:string }export type ResourceArray =Resource[]

 方法二:数组泛型字面量形式

export type ReArray=Array<{_id: string,personID: { _id: string age: string identifier: string name: string nation: string grade: string schemeNum: string organ: string sex: string}gaintestPoint:stringlooktestPoint:string[]viocetsetPoint:stringgameReview:stringAddvice:string }>

或者你也可以这么写

索引签名的方式不能被推断为一个数组,因此不能用来约束数据

这是一种比较常见的约束数据的接口定义

// * 请求响应参数(不包含data)export interface Result {resp_code: string;msg: string;status_code: 200}// * 请求响应参数(包含data)export interface ResultData<T = any> extends Result {data: T;}TS中快速定义一个对象数组以及处理async await的异常(ts中如何定义一个数组)

 接下来我们请求数据可能会这样写,这是一种严格的数据约束,包括定义响应式数组push接口数据,如果这里没有传入泛型则会报错

let result = reactive<ReArray>([])const getResult = async () => { const { data } = await http.get<ResultData<ReArray>>('/user/getpoints') result.length = 0 result.push(...data )}

但这里我们没法处理接口报错的情况,比较常规的写法是try catch 这是一直非常啰嗦的写法,让我们的代码变丑,一种比较优雅的形式是引入await-to-js 

安装命令  npm i await-to-js --save

使用

import to from 'await-to-js';

接下来我们的写法就变成

let result = reactive<ReArray>([])const getResult = async () => {const [err,res] =await to<ResultData<Resource[]>>(http.get('/user/getpoints')) const {data} = resresult.push(...data )}

但这里事实上ts会帮我们类型推导出data有可能不存在

 这时候我们可以使用非空断言!

这样就不会报错了 

to返回的是一个数组

我们可以在if语句里判断err是否存在,从在再去处理逻辑

本文链接地址:https://www.jiuchutong.com/zhishi/297545.html 转载请保留说明!

上一篇:目标检测算法——YOLOv7改进|增加小目标检测层(目标检测算法有哪些)

下一篇:MATLAB与图像处理的那点小事儿~(matlab用于图像处理)

  • 留抵税额退税怎么做账
  • 计提应交个人所得税分录怎么做
  • 全国税收调查表企业表怎么填
  • 持有至到期投资核算内容
  • 个体户开电子发票需要交税吗
  • 其他应收款平账怎么做分录
  • 进项税未抵扣进账了怎么处理
  • 业务招待费扣除基数的收入包括哪些
  • 一人有限公司年度审计报告
  • 税务发票上的二维码
  • 跨年的材料专票怎么做会计分录?
  • 金融企业贷款损失准备金税前扣除计算
  • 防伪税控发票
  • 自产农产品加工后仍属于附注的农产品,免税吗?
  • 已经入库的商品出库了要怎么做会计分录
  • 跨年发票冲红重新开具购买方做账不
  • 特许权使用费预扣预缴计算方法
  • 机打发票丢失如何处理报销
  • 印花税实收资本纳税义务发生时间
  • 小规模企业如何
  • 企业会计准则应用案例
  • 新租赁准则承租人计提折旧吗
  • 金蝶采购发票怎么红冲
  • 记账凭证需要哪些人员签章
  • 招待费进项税额转出在申报表
  • 预缴增值税的情况四种情形汇总表怎么填
  • window10系统有几种
  • 手把手教你linux
  • 累积带薪缺勤的例题
  • 期间费用属于间接生产费用吗
  • 支付代销手续费缴纳增值税吗
  • vue设置时间格式
  • php怎么读取txt
  • phpfread
  • 同一控制下企业合并会计准则
  • easyui分页传递表单参数
  • 记录一次排查PHP脚本执行卡住的问题
  • web渗透违法吗
  • 专票认证期限多长时间
  • 研发费用怎么体现
  • mongodb项目使用说明
  • 预交的企业所得税需要计提吗?
  • 所得税视同销售行为有哪些呢?
  • 公司纳税信用等级B级是什么意思
  • ibm.data.db2
  • 购买银行理财产品的几个必须知道
  • 水电费发票没有可以用其他发票抵吗
  • 房地产企业沙盘模拟
  • 收到免税发票怎么做账
  • 施工企业如何确权
  • 土地增值税税率怎么算
  • 投资收益科目的借贷
  • 工程发票可以分两次开吗
  • 会计做内账的技巧与方法
  • 建筑业分包税收政策
  • windowsxp怎么隐藏桌面图标
  • win2003加速开机
  • 如何安装win7系统教程
  • windows系统后台不显示QQ等软件(任务栏右侧不显示QQ图标)
  • RegSrvc.exe - RegSrvc是什么进程 有什么用
  • igfxem是什么软件
  • win7注册表详解
  • centos6.x下安装maven CentOS自动安装Maven的方法
  • mac装xp系统
  • linux删除定时任务
  • linux error 27:unrecognized command
  • win7j
  • WIN7系统如何恢复出厂系统
  • windows10mobile壁纸
  • win7系统出现蓝屏怎么进去桌面
  • unity 移动应用开发
  • cocos2d用什么语言开发游戏
  • 深入解析java编译器:源码剖析与实例详解
  • 在JavaScript中声明变量的关键词有
  • jquery的认识和使用
  • android进度条对话框
  • 先征后返的增值税计入哪个科目
  • 建筑工程合同首付款
  • 汽车排量与购置税的关系
  • 济南特色没事
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设