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

  • 丢失增值税专用发票最新规定
  • 非盈利组织免税资格文件
  • 房地产增值税抵减土地出让金
  • 公司对公账户给员工发工资税是谁扣
  • 工资可以直接进管理费用吗
  • 个人转款到对公账户会计分录
  • 减免的所得税额怎么入账
  • 防伪税控开票系统技术维护费
  • 合伙企业个人所得税怎么申报
  • 财务费用做什么明细账
  • 收到投资者购买股票的资金
  • 差旅费补贴需要缴纳个人所得税吗需要发票
  • 一般纳税人开普票要交税吗
  • 为什么营收高利润低
  • 财税〔2017〕39号
  • 劳务公司的税率是多少经营模式
  • 临时建筑进项税可以一次抵扣吗?
  • 案例分析正当防卫
  • 2019年收入不足6万如何退税
  • 服务业增值税如何计算
  • 小规模银行存款多笔小金额财务费用可以合并记账吗?
  • 个人独资企业的特点
  • 个人可以做代理吗
  • 地下车库怎么缴费
  • 本地磁盘c满了怎么清理
  • php中mysqli怎么连接数据库
  • 库存呆滞品处理方法
  • win11系统怎么投屏
  • 退回多收款项,提现金,如何做账
  • 公司和个人分别交税一部分吗
  • au_.exe是什么进程
  • 交易性金融资产公允价值变动计入
  • 注销公司需要缴纳注册资金吗
  • 兰斯洛特
  • 增值税已认证抵扣
  • 网络安全实验室
  • gfortran编译命令
  • 商业承兑汇票和银行承兑汇票的分录
  • 一般纳税人购进免税农产品如何抵扣进项税额
  • 公司向法人借款会计分录
  • 公司逾期交税,后期补上有何后果
  • 为什么实收资本是贷方
  • 代理费属于
  • 费用报销票跨月可以用吗
  • 发票已经报送怎么处理
  • 购买金税盘抵税会计分录
  • 其他应付款如何清零
  • 出口货物免税的税种包括
  • 运输费用增值税税率9%
  • 增值税销项税率是多少
  • 进项税额转出缴税放在什么科目里
  • 刚开业的健身房
  • 税率计税依据
  • 网站和店铺的区别
  • win10入门全教程视频
  • redhat语言设置中文
  • win8怎么升级到win7
  • ubuntu安装lamp
  • linux 常用 命令
  • window预览
  • 如何配置sendmail
  • 学会这8个技巧让你做出的菜味道更好
  • linux查看系统日志
  • unity3d ide
  • js math.js
  • ubuntu重新安装网卡驱动
  • shell脚本语句
  • nodejs入门教程
  • android设计模式的应用场景
  • jquery鼠标点击事件怎么写
  • python datetime.now
  • javascript scrollLeft,scrollWidth,clientWidth,offsetWidth 完全详解
  • python操作access数据库
  • js编写一个标准的单例模式类
  • python二分法查找
  • 黑龙江电子税务局
  • 电子税务局第一次申请发票流程
  • 纳税申报期限和税款缴纳期限一样吗
  • 云南医保可以网上买药吗
  • 租房协议中怎样签字
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设