对象的类型注解:
ts的对象是结构化的,结构简单来说就是对象有什么属性或方法
在使用对象前,就可以根据需求,提前设计好对象的结构
如:
let obj:{
uName: string;//声明字符串类型
age: number;//声明数值类型
}
obj={
uName:"张三",
age:18,
}
这就是对象的结构化类型,即:建立一种契约,约束对象中属性值得类型
对象中方法的类型注解:
let p1={
sayHi:()=>{
console.log("hi")
}
}
上述对象的类型注解为:
let p1: {
sayHi: () => void;
}
有参数、无参数、有返回值、无返回值的方法注解类型是不同的,基本的对象中方法的类型直接有以下三种:
()=>void //无参数无返回值
(name: string)=>void //有参数,无返回值
(num1L number,num2: number)=>number//有参数有返回值,返回值类型为数值型
箭头(=>)左边小括号中内容表示方法的参数
箭头右边的内容表示返回值类型
有时我们初学者可能不知道如何去写对象中方法的类型注解,这时我们可以按普通方法写出自己想要的对象及其方法,然后将鼠标悬停在对象名或方法名上,然后vscode会弹出提示,提示内容就是该类型注解