TypeScript 是 "强类型" 版的 JavaScript,当我们在代码中定义变量(包括普通变量、函数、组件、hook等)的时候,TypeScript 允许我们在定义的同时指定其类型,这样使用者在使用不当的时候就会被及时报错提醒
interface SearchPanelProps {
users: User[],
param: {
name: string;
personId: string;
},
setParam: (param: SearchPanelProps['param']) => void;
}
export const SearchPanel = ({users, param, setParam}: SearchPanelProps) => {}
经常用 TypeScript 的感受:比起原来的 JavaScript,TypeScript 带来了完全不一样的开发体验,bug 大大减少了,编辑器提示快了,代码更易读了, 开发速度快了(看似多写代码,其实由于前面几点节省了大量开发时间),上手了就回不去了
在本节中我们使用到了8种类型: number, string, boolean, 函数, array, any, void, object
这一节我们接触到了平常使用中会接触到的大部分的类型,下面我们挨个梳理一遍:
数字类型,包含小数、其他进制的数字:
let decimal: number = 6;
let hex: number = 0xf00d;
let binary: number = 0b1010;
let octal: number = 0o744;
let big: bigint = 100n;
字符串
let color: string = "blue";
在 TS 中,array 一般指所有元素类型相同的值的集合,比如:
let list: Array<number> = [1, 2, 3];
// or
interface User {
name: string
}
const john = {name: 'john'}
const jack = {name: 'jack'}
let personList = [john, jack] // 这里 john 和 jack 都是 User 类型的
和这种混合类型的 "数组":
let l = ['jack', 10]
在 TS 中不是 数组/array,它们叫作 tuple,下面会提到