位置: 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用于图像处理)

  • 个人所得税申诉已受理多久出结果
  • 浙江增值税专用发票几个点
  • 增值税专用发票有效期是多长时间
  • 企业收到退回的所得税的账务处理
  • 小规模差额征税全额开票和差额开票
  • 股东股权比例怎么分配
  • 公司出租非自有房产
  • 关税滞纳金会计怎么做账
  • 税费改革是什么
  • 采购商品未入库的会计分录
  • 公交补贴收入账务处理怎么做?
  • 应交税金减免税金需要结转吗
  • 分配利润和分配股利
  • 出口免费样品发票怎么开
  • 开具旧税号也能认证成功
  • 资产负债表的应收票据包括什么
  • 企业外购材料的入账价值包括
  • 地方教育附加什么时候交
  • 文化事业建设费2023年是否减免了
  • 原版win10系统安装方法
  • 筹建期银行手续费
  • 税收保全措施的期限一般不超过几个月
  • 进项抵扣发票如何查询
  • 企业借款会计处理
  • 稽查查补税款会计分录
  • 基建费用如何摊销
  • 买税控盘的钱怎么做账
  • Win11 Build 25336 预览版发布:Snap 窗口新增最近 20 个标签选项
  • php数据统计源码
  • 融资租出固定资产计入什么科目
  • 商品发生销售退回
  • dedecms批量发文章
  • rust 前端开发
  • 物流公司进项包括什么
  • 现金折扣属于什么
  • 个人生产经营所得范围
  • 长期股权投资大白话解释
  • access 运行sql
  • 收到银行开具的利息发票怎么做账
  • 固定资产办理竣工结算之后的处理方式
  • 工会经费到底是什么
  • 社保个税申报是什么意思
  • 电子承兑背书一般多久到账
  • 关于小规模纳税人的说法正确的是
  • 财付通支付备付金
  • 速动比率和流动比率怎么分析
  • 实收资本现金入账怎么办
  • 出口退回的增值税计入哪个会计科目
  • 中小企业的资产负债率均值是多少
  • 停产期间制造费用如何处理
  • 社会团体收到财政拨款
  • 虚开发票但是没有成本如何做账?
  • 固定资产转为投资性房地产的账务处理公允价值
  • 销售费用可以提现吗
  • 党建经费可以购买什么
  • 小型便利店靠什么进行营利
  • iis6设置
  • windows xp打开服务
  • mac系统操作的小技巧
  • windowxp操作系统
  • mac合盖不休眠怎么办
  • os x 10.10.5
  • win8的计算器在哪里
  • win7系统宽带连接651
  • win8如何更改用户名字?
  • win10系统免费升级
  • javascriptcsdn
  • easyui datagrid resize
  • 批处理常用命令
  • 下列关于android的说法中,错误的是
  • unity中time.time
  • 如何用node搭建服务器
  • 原生js实现promise.all
  • 安卓瀑布流
  • webview设置ua
  • jquery显示隐藏div
  • 重庆税务局官网发票查询
  • 大米可以抵扣增值税吗
  • 海南省税务局长
  • 八戒财税兼职
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设