typescript 参数可空的几种情况

参数可为空技巧

  • ?:参数可空
interface ObjType {
    key1?: string
    key2?: number
}
function test(obj: ObjType) {
    console.log(test)
}
// 此时调用时?:的参数可空
test({ key1: 'test' })
  • 当使用空属性时需要判断
function test(obj: ObjType) {
// 此时ts会抛出错误,key2可能未定义
  console.log(obj.key2++)
}
// 解决:(如果属性特别多判断非常麻烦)
function test(obj: ObjType) {
  if(obj.key2) console.log(obj.key2++)
}
//-----
// 如果你的需求是
function test(obj: ObjType) {
  // 即使你确认赋值了,使用obj2.key2时ts也会抛出错误
  let obj2: ObjType = Object.assign({ key1: 'test', key2: 1 },obj)
  console.log(obj2.key2++)
}
test({key1:'test'}) // 此时默认key2:1
// 解决方式一
function test(obj: ObjType) {
// 已经确定赋值
  obj = { key1: 'test', key2: 2 }
// 使用属性时加上!,ts2.0时新增属性,自己已经确知该属性不为空
  console.log(obj.key2!++)
}
// 解决方式二
function test(obj: Required<ObjType>) {
    // 已经确定赋值
    obj = { key1: 'test', key2: 2 }
    // 使用属性时加上!,ts2.0时新增属性,自己已经确知该属性不为空
    console.log(obj.key2++)
}

主要问题可空参数,确认赋值后,的转换
● 可以通过!,确认
● 可以通过 Required 转换为必填,当然也有 Partial 转换选填

  • 默认值方式参数可空
interface ObjType {
    key1: string
    key2: number
}
function test(obj: ObjType = { key1: 'test', key2: 1 }) {
    console.log(test)
}
// 此时参数可以不填
test()
// 但如果填参数,需满足type
test({ key1: 'test', key2: 2 })
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tommyrunner

你的支持,就是我的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值