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

  • 个税汇算清缴可以修改收入吗
  • 减免所得税额是怎么算出来的12行
  • 已付预付款当月应付金额怎么填写?
  • 收到扶贫款怎么做会计分录
  • 出售未计提完折旧的固定资产
  • 城建税借贷方向
  • 成本 费用区别
  • 外包工加工工资怎么结算
  • 交易性金融资产的账务处理
  • 个体户购买社保和自由人购买社保区别
  • 预缴税款是否可以强制执行
  • 收款凭证填写模板下载
  • 银行如何做存款
  • 税收滞纳金什么意思
  • 给供应商付款怎么做分录
  • 管理费用多计提了怎么冲
  • 企业收到投资款怎么处理
  • 公司用商标权作假违法吗
  • 集体土地上的不动产能符合异议28条规定吗
  • 合同和付款单位不一致发票应该开给谁
  • 没有进项发票怎么出口报关
  • 第三方支付模式的交流流程
  • 以下凭证免征印花税的有
  • 职工教育经费是多少
  • 成品油发票应该怎么冲红?
  • 银行转账取得的收据
  • 过桥不得停车
  • 企业注销固定资产处理
  • 怎么在bios中开启硬件虚拟化
  • 税金及附加多计提所得税年报怎么更正
  • 其它业务收入是什么科目
  • 收到预付款计入什么科目
  • PHP:pg_send_query_params()的用法_PostgreSQL函数
  • vue3中使用require
  • 其他业务成本的意思
  • 供水公司与用户合作协议
  • 巴尼奥斯附近的阿格杨瀑布
  • 医院个人缴费什么意思
  • 那慕尔省
  • 基建费用如何摊销
  • 杜布罗夫尼克老城去机场
  • vue router怎么传值
  • afn取消请求
  • 对供应商的罚款通知怎么写
  • 油气勘探开发
  • 开具劳务发票需要提供什么资料?
  • 增值税电子发票怎么下载
  • 本月应付电费400元,下月支付
  • 什么叫资本退出
  • 深入浅析SQL Server 触发器
  • 以前年度的企业所得税怎么入账
  • 残保金相关内容有哪些
  • 普通发票上的银行账户有规定吗
  • 如何恢复sql server误删除的数据库
  • 母子公司收入合并
  • 电子税务局没有增值税申报怎么办?
  • 会计估计变更和政策变更有哪些
  • 公司购买商品房能折旧吗
  • 应扣未扣税款对纳税人的处理
  • 销售完一定要结工资吗
  • 期间费用明细表在哪里找
  • 固定资产净额怎么计算公式
  • 企业建账的流程有哪些
  • Win7、WinXP下MySql安装出错完全卸载的方法步骤
  • mysql5.7.
  • 通过T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填充数据
  • mysql单表10亿
  • 微软历代操作系统
  • 如何删除windows media center
  • Windows Vista和Windows 7对比
  • centos 7.0截屏快捷键有冲突该怎么更换?
  • centos yum报错
  • windows8.
  • safeplugin是什么软件
  • win7启动发生异常i/0错误
  • js中创建对象的几种方法
  • android触屏事件的处理
  • c#中延时
  • 国税手撕发票图片
  • 满五唯一是指省内还是本市
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设