TypeScript vs JavaScript
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 大大减少了,编辑器提示快了,代码更易读了, 开发速度快了(看似多写代码,其实由于前面几点节省了大量开发时间),上手了就回不去了。
TypeScript 的类型
8 种类型: number, string, boolean, function, array, any, void, object
1. number
数字类型,包含小数、其他进制的数字:
let decimal: number = 6;
let hex: number = 0xf00d;
let binary: number = 0b1010;
let octal: number = 0o744;
let big: bigint = 100n;
2. string
字符串
let color: string = "blue";
3. array
在 TS 中,array 一般指所有元素类型相同的值的集合,比如:
let list: Array = [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
4. boolean
布尔值:
let isDone: boolean = false;
5. 函数
两种方法:
1.在我们熟悉的 “JS 函数” 上直接声明参数和返回值:
const isFalsy = (value: any): boolean => {
return value === 0 ? true : !!value;
};
2.直接声明你想要的函数类型:
export const useMount = (fn: () => void) => {
useEffect(() => {
fn();
}, []);
};
const isFalsy: (value: any) => boolean = (value) => {
return value === 0 ? true : !!value;
};
6. any
any 表示这个值可以是任何值,被定义为 any 就意味着不做任何类型检查:
let looselyTyped: any = 4;
// looselyTyped 的值明明是个4,哪里来的ifItExists方法呢?
// 由于声明为any,我们没法在静态检查阶段发现这个错误
looselyTyped.ifItExists();
应该尽量避免使用 any
7. void
绝大部分情况下,只会用在这一个地方:表示函数不返回任何值或者返回 undefined (因为函数不返回任何值的时候 === 返回 undefined)
export const useMount = (fn: () => void) => {
useEffect(() => {
fn();
}, []);
};
8. object
除了 number, string, boolean, bigint, symbol, null, or undefined,其他都是 object。
9. tuple
这就是一个典型的 tuple:
const [users, setUsers] = useState([])
10. enum
enum Color {
Red,
Green,
Blue,
}
let c: Color = Color.Green;
11. null 和 undefined
null 和 undefined 在 TypeScript 中既是一个值,也是一个类型:
let u: undefined = undefined;
let n: null = null;
12. unknown
unknown 表示这个值可以是任何值。
这句话怎么这么熟悉,刚才是不是用来形容 any 的?
unknown 的用法:在你想用 any 的时候,用 unknown 来代替,简单来说,unknown 是一个 "严格" 版的 any。
13. never
这个 func返回的就是never类型,用到比较少,在类型操作等场景会用到
const func = () => {
throw new Error()
}
.d.ts
JS 文件 + .d.ts 文件 === ts 文件。
.d.ts 文件可以让 JS 文件继续维持自己 JS 文件的身份,而拥有 TS 的类型保护。
一般我们写业务代码不会用到,但是点击类型跳转一般会跳转到 .d.ts 文件。