typescript一些语法糖

typescript一些语法糖

单个问号 ? 在定义类型里,代表非必须,可以帮助ide和lint进行静态检查

  type UserInfo = {
    username?: string;
  }

单个问号 ? 用于属性读取,表示如果不存在则返回空,减少一些检查空值的代码。

const val=data?.error.code;

单问号 ? 用在function参数定义里,表示这个参数并不是必须的,可省略,方便ide/lint来检查

function test(paramA: string, paramB?: string){
    // paramB is not required
}

单问号 ? 用作三元运算符,这个就是常见的

const val= num>0 ? valA : valB;

双问号 ?? ,如果前一个值是null/undefined则返回后一个值,主要用于default value,这个与 || 是差不多的

const val= valA ?? valB;

单感叹号 ! 用在类型里的字段定义

interface B{
    name?: string
}
class A implemented B{
    name!: string
}

单感叹号 ! 在对象调用属性或函数时,提示ide/lint等这个属性是一定会存在的,会避免静态编译错误。

new Error().stack!.split('\n');

你可能感兴趣的:(typescript,antd,reactjs)