Jira项目笔记15:深入探索TypeScript类型系统


TypeScript 的类型

 8 种类型: number, string, boolean, 函数,array, any, void, object

这一节我们接触到了平常使用中会接触到的大部分的类型,下面我们挨个梳理一遍:

  • number:数字类型,包含小数、其他进制的数字
let decimal: number = 6;
let hex: number = 0xf00d;
let binary: number = 0b1010;
let octal: number = 0o744;
let big: bigint = 100n;
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • string:字符串
let color: string = "blue";
  • 1.
  • array:在 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 类型的
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.

和这种混合类型的 “数组”:

let l = ['jack', 10]
  • 1.

在 TS 中不是 数组 /array,它们叫作 tuple,下面会提到。

  • boolean:布尔值
let isDone: boolean = false;
  • 1.
  • 函数

在我们熟悉的 “JS 函数” 上直接声明参数和返回值:

/**
* 这是我们上节课写的代码,大家可能发现了
* 我在这里做了一些修改,在箭头前边加上了 :boolean
* 但是在我们上节课的代码中是没有这个:boolean 的,
* 之所以不需要加是因为 类型推断,这个我们在下面会讲
* @param value
*/
const isFalsy = (value: any): boolean => {
return value === 0 ? true : !!value;
};
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.

直接声明你想要的函数类型:

/**
* 上节课写的 useMount 和 isFalsy
*/
export const useMount = (fn: () => void) => {
useEffect(() => {
fn();
}, []);
};

const isFalsy: (value: any) => boolean = (value) => {
return value === 0 ? true : !!value;
};
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • any

any 表示这个值可以是任何值,被定义为 any 就意味着不做任何类型检查:

let looselyTyped: any = 4;
// looselyTyped 的值明明是个4,哪里来的ifItExists方法呢?
// 由于声明为any,我们没法在静态检查阶段发现这个错误
looselyTyped.ifItExists();
  • 1.
  • 2.
  • 3.
  • 4.

初学 TS 的同学经常会为了让 TS 不再报错就用了很多 any,这样做会失去 TS 的保护。同学们应该尽量避免使用 any

  • void

绝大部分情况下,只会用在这一个地方:表示函数不返回任何值或者返回 undefined (因为函数不返回任何值的时候 === 返回 undefined)

/**
* 上节课写的 useMount
*/
export const useMount = (fn: () => void) => {
useEffect(() => {
fn();
}, []);
};
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • object

除了 number, string, boolean, bigint, symbol, null, or undefined,其他都是 object。

下面是我们还没有接触到的 TS 类型。

  • tuple

其实这个大家已经见过了,这是没有给大家指出来。

这就是一个典型的 tuple:

const [users, setUsers] = useState([])
  • 1.

tuple 是 “数量固定,类型可以各异” 版的数组。

在 React 中有可能使用 tuple 的地方就是 custom hook 的返回值,注意 isHappy → tomIsHappy 以及其他名字的变化,这里使用 tuple 的好处就显现出来了:便于使用者重命名:

const useHappy = () => {
//....
return [isHappy, makeHappy, makeUnHappy]
}

const SomeComponent = () => {
const [tomIsHappy, makeTomHappy, makeTomUnHappy] = useHappy(false)
// ...
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • enum
enum Color {
Red,
Green,
Blue,
}
let c: Color = Color.Green;
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • null 和 undefined

null 和 undefined 在 TypeScript 中既是一个值,也是一个类型:

let u: undefined = undefined;
let n: null = null;
  • 1.
  • 2.
  • unknown

unknown 表示这个值可以是任何值。

这句话怎么这么熟悉,刚才是不是用来形容 any 的?

unknown 的用法:在你想用 any 的时候,用 unknown 来代替,简单来说,unknown 是一个 "严格" 版的 any。

const isFalsy = (value: unknown) => {
// 大家不用考虑这段console有啥意义,把它打在你的代码里对应的位置,观察编辑器会不会报错;
// 再思考它应不应该报错
console.log(value.mayNotExist)
return value === 0 ? true : !!value;
};
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • never
// 这个 func返回的就是never类型,用到比较少,在类型操作等场景会用到
const func = () => {
throw new Error()
}
  • 1.
  • 2.
  • 3.
  • 4.
  • interface

interface 不是一种类型,应该被翻译成 接口,或者说使用上面介绍的类型,创建一个我们自己的类型:

interface User {
id: number;
}
const u: User = {id: 1}
  • 1.
  • 2.
  • 3.
  • 4.
QR Code
微信扫一扫,欢迎咨询~

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 155-2731-8020
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

手机不正确

公司不为空